CCF CSP 编程题目和解答-----试题名称:工资计算-------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。






/**经过分析发现所有的输入数据是100的整数倍,同时小于100000
所以就算是枚举所有可能的工资收入所需要的计算量也只有1000的数量级左右
所以在大于3500的时候使用枚举的方式,计算出该收入下的实际所得工资与输入是否相等,
如果相等则输出,如果不相等则依次递增100.所以实现的基本思想就是枚举
**/

//以下代码是本人按照自己的理解所写,不一定就是最好的解决思路,有大佬有更好的解决方法欢迎指正

#include<iostream>  
#include<vector>  
#include<string>  
#include<bitset>  
#include<map>  
#include<algorithm>  
#include<queue>  


using namespace std;


long long get_tax(long long in)//计算收入为in的情况下需要交的税的数目
{
	double tax = 0;
	if (in <= 3500)
		return 0;
	else
	{
		int A = in - 3500;
		if (A - 1500 > 0)
		{
			tax += 1500 * 0.03;
			A = A - 1500;
			if (A > 3000)
			{
				tax += 3000 * 0.1;
				A = A - 3000;
				if (A > 4500)
				{
					tax += 4500 * 0.2;
					A = A - 4500;
					if (A > 26000)
					{
						tax += 26000 * 0.25;
						A = A - 26000;
						if (A > 20000)
						{
							tax += 20000 * 0.3;
							A = A - 20000;
							if (A > 25000)
							{
								tax += 25000 * 0.35;
								A = A - 25000;
								tax += A * 0.45;
							}
							else
							{
								tax += A*0.35;
							}
						}
						else
						{
							tax += A*0.3;
						}
					}
					else
					{
						tax += A*0.25;
					}
				}
				else
				{
					tax += A*0.2;
				}
			}
			else
			{
				tax += A*0.1;
			}
		}
		else
		{
			tax += 0.03*A;
		}
	}

	return (long long)tax;
}


int main()
{
	long long T = 0;
	cin >> T;
	if (T <= 3500)//小于3500不交税
	{
		cout << T << endl;
	}
	else {                            //大于3500使用枚举遍历
		for (int i = 0; i < 1000; i++)
		{
			long long S = 3500 + 100 * i;
			long long t = S - get_tax(S);
			if (t == T)
				cout << S<<endl;
			
		}
	}


}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值