https://pintia.cn/problem-sets/994805260223102976/problems/994805290334011392
简单题。
#include<iostream>
#include<string.h>
using namespace std;
int main() {
int n, sum, flag=0, wei[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
char m, ch[11]={'1','0','X','9','8','7','6','5','4','3','2'};
cin >> n;
string str[n];
for(int i=0; i<n; i++){
cin >> str[i];
sum = 0;
for(int j=0; j<str[i].size()-1; j++)
sum += (str[i][j]-'0')*wei[j];
sum = sum % 11;
m = ch[sum];
if(m != str[i][str[i].size()-1]){
flag = 1;
cout << str[i] << endl;
}
}
if(flag == 0)
cout << "All passed" << endl;
return 0;
}
该代码实现了一个简单的程序,用于验证输入的中国身份证号码的校验位是否正确。通过计算身份证号码前17位数字的加权和,并取模得到校验位,然后与身份证号码最后一位进行比较,如果不同则输出该身份证号码,否则输出All passed。
538

被折叠的 条评论
为什么被折叠?



