CCF CSP 工资计算

来源:互联网 发布:乌龙山伯爵 知乎 编辑:程序博客网 时间:2024/05/17 04:59

CCF CSP 工资计算

题目

问题描述
试题编号:201612-2 试题名称:工资计算 时间限制:1.0s 内存限制:256.0MB 问题描述:
问题描述
  小明的公司每个月给小明发工资,而小明拿到的工资为交完个人所得税之后的工资。假设他一个月的税前工资(扣除五险一金后、未扣税前的工资)为S元,则他应交的个人所得税按如下公式计算:
  1) 个人所得税起征点为3500元,若S不超过3500,则不交税,3500元以上的部分才计算个人所得税,令A=S-3500元;
  2) A中不超过1500元的部分,税率3%;
  3) A中超过1500元未超过4500元的部分,税率10%;
  4) A中超过4500元未超过9000元的部分,税率20%;
  5) A中超过9000元未超过35000元的部分,税率25%;
  6) A中超过35000元未超过55000元的部分,税率30%;
  7) A中超过55000元未超过80000元的部分,税率35%;
  8) A中超过80000元的部分,税率45%;
  例如,如果小明的税前工资为10000元,则A=10000-3500=6500元,其中不超过1500元部分应缴税1500×3%=45元,超过1500元不超过4500元部分应缴税(4500-1500)×10%=300元,超过4500元部分应缴税(6500-4500)×20%=400元。总共缴税745元,税后所得为9255元。
  已知小明这个月税后所得为T元,请问他的税前工资S是多少元。
输入格式
  输入的第一行包含一个整数T,表示小明的税后所得。所有评测数据保证小明的税前工资为一个整百的数。
输出格式
  输出一个整数S,表示小明的税前工资。
样例输入
9255
样例输出
10000
评测用例规模与约定
  对于所有评测用例,1 ≤ T ≤ 100000。

代码

简单模拟

#include <iostream>#include <cstdio>#include <algorithm>using namespace std;int laterSalary[] = {3500, 1455, 2700, 3600, 19500, 14000, 16250, 100000};long double rate[] = {1.0f, 0.97f, 0.9f, 0.8f, 0.75f, 0.7f, 0.65f, 0.55f};int n = sizeof(laterSalary) / sizeof(laterSalary[0]);int main(){    int s;    while(scanf("%d",&s) != EOF){        long double realSalary = 0.0f;        int index = 0;        while(index < n && s >= 0){            int min_value = min(laterSalary[index], s);            s -= min_value;            realSalary += min_value / rate[index];            index++;        }        int ans = (int)(realSalary + 0.0001);        printf("%d\n",ans);    }    return 0;}
原创粉丝点击