【pta】1031 查验身份证
题目
1031 查验身份证
思路
把权值存入数组a中,把M存入数组b中。对于没有错误的情况,设置一个flag变量,只要有不合格的输出,就把值设为1。
代码
#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};
bool istrue(string s)
{int sum = 0;for (int i = 0;i < s.size()-1;i++){if (!isdigit(s[i]))return false;sum = sum + a[i] * (s[i] - '0');}if ((sum % 11) == 2){if (s[17] != 'X')return false;}else{if (b[sum % 11] != s[17]-'0')return false;}return true;
}
int main()
{int n;cin >> n;string s;int flag = 0;for (int i = 0;i < n;i++){cin >> s;if (!istrue(s)){cout << s << endl;;flag = 1;}}if (flag == 0)cout << "All passed";return 0;
}