2021-02-26

CCF-CSP\专题\题型A 简单模拟\201612-2 工资计算

算是比较复杂的简单模拟了,主要难点在于税后工资的计算,因为情况太多,开了一个数组保存税率和下界,然后注意枚举每个税率不同的区间(当然是按税率从低到高枚举),如果当前区间的上界小于等于税前工资A,就扣除当前区间对应的税,否则退出循环,把逻辑搞清楚就行。

然后坑点还有保证税前工资是整百。如果用线性查找(也能过,真的!),就每次递增100,如果用二分查找,就注意要对整百进行查找,即用1代表100,2代表200等等,否则当二分除以二的时候,就会有问题。

#include <cstdio>
/*
税前工资S,税后工资T,T=f(S),则f是增函数。
小明的公司每个月给小明发工资,而小明拿到的工资为交完个人所得税之后的工资。
假设他一个月的税前工资(扣除五险一金后、未扣税前的工资)为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元。
*/

const int P[][2]={{0, 3},{1500, 10},{4500,20},{9000,25},{35000,30},{55000,35},{80000,45}};
const int lenP=sizeof(P)/sizeof(P[0]);

// 由税前工资,计算税后工资。 
int f(int S) {
	if (S <= 3500) return S;
	int A=S-3500;
	for (int i=0;i<lenP;++i) {
		int left=P[i][0];
		int right=A;
		if (i!=lenP-1 && P[i+1][0]<A) {
			right=P[i+1][0];
		}
		if (left >= right) break;
		int rate=P[i][1];
		int cost=(right-left)*rate/100;
		S -= cost;
	}
	return S;
}

/* run this program using the console pauser or add your own getch, system("pause") or input loop */

#define MAXT 100000
#define MAXS 154400

void GetMaxS() {
	int S=0;
	while (1) {
		int T=f(S);
		if (T > MAXT) break;
		printf("S %d T %d\n", S, T);
		S += 100;
	}
}

/*
一个关键的条件:
题目保证S是整百的数,所以枚举的数据必须是整百的。
*/ 
void Search(int left, int right, int T) {
	while (left <= right) {
		int mid=(left+right)/2;
		int t=f(mid*100); // 整百。 
//		printf("t %d mid %d\n", t, mid);
		
		if (t == T) {
			printf("%d\n", mid*100);
			return;
		}
		if (T < t) {
			right=mid-1;
		} else {
			left=mid+1;
		}
	}
}

/*
由于数据T较小,才10万,顺序搜索不会超时,
不必二分查找。
*/
 
int main(int argc, char** argv) {
	int T;
	scanf("%d", &T);
	// 二分查找。 
	Search(1, MAXS/100, T);
	return 0;
	
	// 线性查找。 
	int S=100;
	while (f(S) != T) {
		S += 100;
	}
	printf("%d\n", S);
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2021-03-26 20:54:33,596 - Model - INFO - Epoch 1 (1/200): 2021-03-26 20:57:40,380 - Model - INFO - Train Instance Accuracy: 0.571037 2021-03-26 20:58:16,623 - Model - INFO - Test Instance Accuracy: 0.718528, Class Accuracy: 0.627357 2021-03-26 20:58:16,623 - Model - INFO - Best Instance Accuracy: 0.718528, Class Accuracy: 0.627357 2021-03-26 20:58:16,623 - Model - INFO - Save model... 2021-03-26 20:58:16,623 - Model - INFO - Saving at log/classification/pointnet2_msg_normals/checkpoints/best_model.pth 2021-03-26 20:58:16,698 - Model - INFO - Epoch 2 (2/200): 2021-03-26 21:01:26,685 - Model - INFO - Train Instance Accuracy: 0.727947 2021-03-26 21:02:03,642 - Model - INFO - Test Instance Accuracy: 0.790858, Class Accuracy: 0.702316 2021-03-26 21:02:03,642 - Model - INFO - Best Instance Accuracy: 0.790858, Class Accuracy: 0.702316 2021-03-26 21:02:03,642 - Model - INFO - Save model... 2021-03-26 21:02:03,643 - Model - INFO - Saving at log/classification/pointnet2_msg_normals/checkpoints/best_model.pth 2021-03-26 21:02:03,746 - Model - INFO - Epoch 3 (3/200): 2021-03-26 21:05:15,349 - Model - INFO - Train Instance Accuracy: 0.781606 2021-03-26 21:05:51,538 - Model - INFO - Test Instance Accuracy: 0.803641, Class Accuracy: 0.738575 2021-03-26 21:05:51,538 - Model - INFO - Best Instance Accuracy: 0.803641, Class Accuracy: 0.738575 2021-03-26 21:05:51,539 - Model - INFO - Save model... 2021-03-26 21:05:51,539 - Model - INFO - Saving at log/classification/pointnet2_msg_normals/checkpoints/best_model.pth 我有类似于这样的一段txt文件,请你帮我写一段代码来可视化这些训练结果
02-06
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值