果然,对于string 太不熟悉了,对这种字符串的题都感到莫名的恐惧,还是要加强联系啊。
问题一:这一堆身份证号码不知道怎么设,用了string数组,但是越写越不对,最后观察了大家的思路才发现只设一个string s,每次输入之后就判断也可啊。。。
问题二:比较字符串最后一位所对应的校验码时,数组M没必要设成整数,可以直接整个char数组啊。。。
问题三:因为要对很多个身份证号进行判断,所以一些变量在 下一次循环开始前应记得改成初始值。
学到了一个新函数:isdigit()判断是否为数字,若是,比如idsdigit(4),则返回值为4,若不是数字,则返回值为0,
#include<iostream>
using namespace std;
#include<ctype.h>
#include<string>
int main()
{
int N, Z;
cin >> N;
string s;
int a[17] = { 7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2 };
char o[11] = { '1','0','X','9','8','7','6','5','4','3','2' };
int flag2 = 0;
for (int i = 0; i < N; ++i)
{ int flag1 = 0,sum=0;
cin >> s;
for (int j = 0; j < s.size() - 1; ++j)
{
if (!isdigit(s[j])&&flag1==0)
flag1 = 1;
sum += (s[j]-'0') * a[j];
}
Z = sum % 11;
if (o[Z] != s[s.size() - 1] || flag1 == 1)
{cout << s << endl;
flag2 = 1;
}
}
if (flag2 == 0)
cout << "All passed";
return 0;
}