题目分析:本题考察字符串的处理,对身份证号前17位进行判断,若存在字母,则直接输出该错误的身份证号,否则对前17位进行加权求和,然后对11取模, 与给定的标准校验码相比较,若相匹配,则该身份证号正确,继续验证下一个,若所有身份证号都正确,输出"All passed"。
解题思路:对字符串进行处理,具体看代码。
#include <iostream>
using namespace std;
int a[17] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
int b[11] = {1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2};
string s;
bool isTrue() {
int sum = 0;
for (int i = 0; i < 17; i++) {
if (s[i] < '0' || s[i] > '9') return false;
sum += (s[i] - '0') * a[i];
}
int temp = (s[17] == 'X') ? 10 : (s[17] - '0');
return b[sum%11] == temp;
}
int main() {
int n, flag = 0;
cin >> n;
for (int i = 0; i < n; i++) {
cin >> s;
if (!isTrue()) {
cout << s << endl;
flag = 1;
}
}
if (flag == 0) cout << "All passed";
return 0;
}