PATB1031.查验身份证(15)

本文介绍了一种用于验证身份证号码有效性的算法。通过17位数字与预设权重相乘求和,并利用余数映射到特定字符集,来确定最后一位校验码是否正确。适用于快速批量验证大量身份证号码的有效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目链接:点击打开链接


知识点笔记:

     1.对一个字符数字,如何判断不是数字

!str[j]>='0'&&str[j]<='9' 

           用asc码来判别


AC代码:

#include <cstdio>

int main() {


	int n;
	int w[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2}; //权
	char M[11]={'1','0','X','9','8','7','6','5','4','3','2'};// 验证码
	scanf("%d",&n);
	bool flag = true;
	char str[20];

	for(int i=0;i<n;i++)
	{
		scanf("%s",str);
		int j,last=0; // last记录前17位的加全和
		for(j=0;j<17;j++){
			if(!str[j]>='0'&&str[j]<='9') break; //非数字
			last=last+(str[j]-'0')*w[j];
		}
		if(j<17){ //有非数字的存在,导致上一个循环没有完整实现,中途break退出
			flag=false;
			printf("%s\n",str);
		}else{
			if(M[last%11]!=str[17]){
				flag=false;
				printf("%s\n",str);
			}
		}
	}
	if(flag == true){
		printf("All passed\n");
	}

	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

猪突猛进!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值