CCF CSP 编程题目和解答-----试题名称:工资计算-------201612-2
2017-03-16 00:24
567 查看
问题描述
/**经过分析发现所有的输入数据是100的整数倍,同时小于100000
所以就算是枚举所有可能的工资收入所需要的计算量也只有1000的数量级左右
所以在大于3500的时候使用枚举的方式,计算出该收入下的实际所得工资与输入是否相等,
如果相等则输出,如果不相等则依次递增100.所以实现的基本思想就是枚举
**/
//以下代码是本人按照自己的理解所写,不一定就是最好的解决思路,有大佬有更好的解决方法欢迎指正
试题编号: | 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。 |
所以就算是枚举所有可能的工资收入所需要的计算量也只有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; } } }
相关文章推荐
- CCF CSP 编程题目和解答-----试题名称:权限查询-------201612-3
- CCF CSP 编程题目和解答-----试题名称:日期计算-------201509-2
- CCF CSP 编程题目和解答-----试题名称:模板生成系统 -------201509-3
- CCF CSP 编程题目和解答-----试题名称: ISBN 号码 -------201312-2
- CCF CSP 编程题目和解答-----试题名称:炉石传说 -------201609-3
- CCF CSP 编程题目和解答-----试题名称:路径解析 -------201604-3
- CCF CSP 编程题目和解答-----试题名称:Z字形扫描-------201412-2
- CCF CSP 编程题目和解答-----试题名称:消除类游戏-------201512-2
- CCF CSP 编程题目和解答-----试题名称:画图 -------201512-3
- CCF CSP 编程题目和解答-----试题名称: 出现次数最多的数 --------201312-1
- CCF CSP 编程题目和解答-----试题名称:相邻数对-------201409-1
- CCF CSP 编程题目和解答-----试题名称:窗口-------201403-2
- CCF CSP 编程题目和解答-----试题名称:俄罗斯方块-------201604-2
- CCF CSP 编程题目和解答-----试题名称:火车购票-------201609-2
- CCF CSP 编程题目和解答-----试题名称:画图-------201409-2
- CCF CSP 编程题目和解答-----试题名称: 最大的矩形 -------201312-3
- CCF CSP试题 201612-2 工资计算
- [CCF-CSP]201612-2(工资计算)
- 【CCFCSP】201612-2 工资计算
- 【CCF CSP】 201612-2 工资计算(100分)