[华为机试练习题]59.奖金提成

简介:

题目

描述:

简要描述:企业发放的奖金根据利润提成。
利润低于或等于100000元的,奖金可提10%;
利润高于100000元,低于200000元(100000≤200000)时;
低于100000元的部分按10%提成;
高于100000元的部分,可提成7.5%;
200000≤400000时,低于200000元部分仍按上述办法提成,(下同);
高于200000元的部分按5%提成;
400000≤600000元时,高于400000元的部分按3%提成;
600000≤1000000时,高于600000元的部分按1.5%提成;
I>1000000时,超过1000000元的部分按1%提成。
从键盘输入当月利润I,求应发奖金总数。

输入:

一个整数,当月利润。

输出:

一个整数,奖金。

例如:

输入900
输出90
备注:奖金向下取整,不作四舍五入处理。

练习阶段:

初级 

代码

/*---------------------------------------
*   日期:2015-07-05
*   作者:SJF0115
*   题目:奖金提成  
*   来源:华为机试练习题
-----------------------------------------*/
#include <iostream>
#include "oj.h"
using namespace std;


/*
功能:
    企业发放的奖金根据利润提成。
    利润低于或等于100000元的,奖金可提10%;
    利润高于100000元,低于200000元(100000<I≤200000)时;
    低于100000元的部分按10%提成;
    高于100000元的部分,可提成 7.5%;
    200000<I≤400000时,低于200000元部分仍按上述办法提成,(下同);
    高于200000元的部分按5%提成;
    400000<I≤600000元时,高于400000元的部分按3%提成;
    600000<I≤1000000时,高于600000元的部分按1.5%提成;
    I>1000000时,超过1000000元的部分按1%提成。
    从键盘输入当月利润I,求应发奖金总数

输入:
    一个整数,当月利润 x

输出:
    无

返回:
    一个整数,奖金

*/

#include <stdlib.h>
#include <stdio.h>

size_t Bonus(size_t profit){
    size_t result = 0;
    while(profit){
        if(profit <= 100000){
            result += profit * 0.1;
            return result;
        }//if
        else if(profit <= 200000){
            result += (profit - 100000) * 0.075;
            profit = 100000;
        }//else
        else if(profit <= 400000){
            result += (profit - 200000) * 0.05;
            profit = 200000;
        }//else
        else if(profit <= 600000){
            result += (profit - 400000) * 0.03;
            profit = 400000;
        }//else
        else if(profit <= 1000000){
            result += (profit - 600000) * 0.015;
            profit = 600000;
        }//else
        else{
            result += (profit - 1000000) * 0.01;
            profit = 1000000;
        }//else
    }//while
    return result;
}
目录
相关文章
力扣1873 计算特殊奖金
力扣1873 计算特殊奖金
|
8月前
三道华为机试题
三道华为机试题
32 0
|
10月前
题目 2664: 蓝桥杯2022年第十三届省赛真题-求和
题目 2664: 蓝桥杯2022年第十三届省赛真题-求和
|
12月前
|
存储 人工智能 BI
P8597 [蓝桥杯 2013 省 B] 翻硬币个人思考总结+第五届传智杯ABC 初赛题解
桌上放着排成一排的若干硬币。我们用 `*` 表示正面,用 `o` 表示反面(是小写字母,不是零),比如可能情形是 `**oo***oooo`,如果同时翻转左边的两个硬币,则变为 `oooo***oooo`。现在小明的问题是:如果已知了初始状态和要达到的目标状态,每次只能同时翻转相邻的两个硬币,那么对特定的局面,最少要翻动多少次呢?
141 0
|
C++
蓝桥杯练习题一 - 生日蜡烛(c++)
蓝桥杯练习题一 - 生日蜡烛(c++)
116 0
AcWing 610. 工资和奖金
AcWing 610. 工资和奖金
101 0
AcWing 610. 工资和奖金
AcWing 672. 税
AcWing 672. 税
55 0
AcWing 672. 税
|
机器学习/深度学习
洛谷每日三题之第一天
洛谷每日三题之第一天
|
C语言
洛谷每日三题--第二天
洛谷每日三题--第二天
|
C语言
浙大版《C语言程序设计(第3版)》题目集 - 习题9-6 按等级统计学生成绩(20 分)
浙大版《C语言程序设计(第3版)》题目集 - 习题9-6 按等级统计学生成绩(20 分)
114 0