2016.12.2 工资计算
目录
前言
最近我在做CCF的题目,也打算把每道题的解题思路都写到博客上来,希望能帮助到也在做CCF题目的读者们,希望你们通过本文能有所提示,帮助大家提升编程能力。另外有个很好的想法就是,建议读者们可以先看一下问题分析这一部分,然后自己再整理一下思路,重新做一遍,最后再参考代码,我想这样会更有收获。
一、问题描述
问题描述
小明的公司每个月给小明发工资,而小明拿到的工资为交完个人所得税之后的工资。假设他一个月的税前工资(扣除五险一金后、未扣税前的工资)为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。
二、问题分析
这道题目需要提前计算一下每个税率区间的交税情况,大致了解一下,然后逆推过去就行了,主要的解题思路如下:
主要就是要算出每个区间的最大税后工资金额,计算的逻辑还是蛮简单的,自己推一下就知道了。接着就循环找出输入的税后工资在哪个区间,这里值得注意的是遍历len(T)+1次(具体可以看下程序,因为这道题不知道怎么说才能更好的表达出来),然后对最后一个值进行判断就行了,让它直接跳出循环;为什么要这么做呢?主要是因为之前用Java写过,Java的遍历是当 i 的值超过遍历范围才退出,而python的遍历不是这样的,比如你写 for i in range(0,7) ,i 的值只到6,而Java是到7才退出。然后+1操作就为了能计算超过最后那个区间的税后金额的情况。
其余部分应该比较容易理解,这里就不详说了。
三、程序说明
r:存储税率的列表
S:存储每个税率区间的原工资最大值的列表
A:S减去3500剩余的部分,即要交税的部分
R:每个税率区间的最大交税金额
T:每个区间的税后工资列表
t:输入的税后工资
python语言的程序如下(100分):
# 工资计算
r = [0.03, 0.1, 0.2, 0.25, 0.3, 0.35, 0.45] # 税率
S = [3500,3500+1500,3500+4500,3500+9000,3500+35000,3500+55000,3500+80000] # 每个税率区间的原工资最大值
A = [(i-3500) for i in S]
R = [0] # 每个税率区间最大交税值
temp = 0
for i in range(1,len(A)):
temp += (A[i]-A[i-1])*r[i-1]
R.append(temp)
T = [(S[i]-R[i]) for i in range(len(S))] # 税后工资区间
t = int(input())
for i in range(len(T)+1):
if i == len(T):
break
elif t <= T[i]:
break
if i == 0:
print(t)
else:
print(int(S[i-1]+(t-T[i-1])/(1-r[i-1])))