201612-2工资计算

一、原题

问题描述
试题编号: 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。


二、分析

这是一道签到题。不够我一开始没有想明白怎么做,浪费了1天时间,光会给出工资算税后,不会给出税后算工资,这大概也是一般的超级普通人(专科?)的思维水平吧。

我提交第一次,不仅编译错误,而且ifelse判断后里面写的也写错了,总之,不只是编译错误而已,而是漏洞百出。

第二次提交时,把发现的错误补上了,然后并没有看到哪里编译可能会出错,于是就交了,预料之中的结果,必然编译错,但是疑惑的是为什么我明知道会编译错还提交,没办法,这不是个好习惯,要有自信。

然后,实在看不出来那20行代码哪里会编译错,于是我又手贱开编译器了,。。。于是分号中有一个一个是中文分号,改了,提交,第三遍,错误,预料之中,我不认为第二题我能一遍交对。。

看了半天看不出哪里错,只能开编译器跑给的测试数据了,一跑,数据不对,看了看,ifelse判断条件和内部写的不匹配,我的思路是把税后的分界点算出来,分别依次ifelse判断,但是这么写坐实有些low啊,于是这里又带了那个问题。不管如何,实现就好,改完提交

第四遍AC。

于是想着用循环写,要不然养不成计算机思维习惯,每次写一堆是不行的,也不能总是我手动算啊,必须得学会偷懒,不能每次都靠自己,我绝对不能去算那些数据去,再少也不行,计算机才是干这种事的,还有加0.5,编译运行后结果不对才反应过来要这么四舍五入。

第五遍,改了又改,思维扭不过去,主要是要不要i-1?循环从水开始?对应关系是个什么形状?这个思维才是最重要的,而不是第四题那种解决问题的方法。

另外,一定牢记一点,CCF是不会告诉你你提交的对不对的,所以!!!!!必须要会自己快速造各种测试数据保证自己对。。。!!!!!



第四遍代码:

#include <iostream>
using namespace std;
int main(){
int t;
cin>>t;
int s;
int a,b,c,d,e,f;
a=3500+1500*0.97;
b=a+3000*0.9;
c=b+4500*0.8;
d=c+26000*0.75;
e=d+20000*0.7;
f=e+25000*0.65;
if(t<=3500){
s=t;
}else if(t>3500&&t<=a){
s=3500+(t-3500)/0.97+0.5;
}else if(t>a&&t<=b){
s=3500+1500+(t-a)/0.9+0.5;
}else if(t>b&&t<=c){
s=3500+4500+(t-b)/0.8+0.5;
}else if(t>c&&t<=d){
s=3500+9000+(t-c)/0.75+0.5;
}else if(t>d&&t<=e){
s=3500+35000+(t-d)/0.7+0.5;
}else if(t>e&&t<=f){
s=3500+55000+(t-e)/0.65+0.5;
}else if(t>f){
s=3500+80000+(t-f)/0.55+0.5;
}
cout<<s;
return 0;
}

第五遍提交

#include <iostream>
using namespace std;
int main(){
int t;
cin>>t;
int s;
float r[8]={1,0.97,0.9,0.8,0.75,0.7,0.65,0.55};
int sv[8]={0,0,1500,4500,9000,35000,55000,80000};
int tv[9]={0,3500};
///sv
int i;
for(i=1;i<8;i++){
    sv[i]+=3500;
}
///tv
for(i=1;i<8;i++){
    tv[i]=tv[i-1]+r[i-1]*(sv[i]-sv[i-1])+0.5;
}
tv[8]=99999999;
for(i=1;i<9;i++){
    if(t<tv[i]){
        s=sv[i-1]+(t-tv[i-1])/r[i-1]+0.5;
        break;
    }
}
cout<<s;
return 0;
}



猜你喜欢

转载自blog.csdn.net/SiKongPop/article/details/79818224