#include<iostream>
#include<cmath>
#include<string>
using namespace std;
int w[17] = { 7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2 };
char z[11] = { '1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2' };
int n;
int main()
{
scanf("%d", &n);
getchar();
int cnt = 0;
while (n--)
{
string s;
getline(cin, s);
int sum = 0;
bool flag = true;
for (int i = 0; i < 17; i++)
{
if (s[i] >= '0'&&s[i] <= '9')
{
sum += (s[i] - '0')*w[i];
}
else
{
flag = false;
break;
}
}
if (flag == false)cout << s << endl, cnt++;
else
{
if (s[s.length() - 1] != z[sum % 11])cout << s << endl, cnt++;
}
}
if (cnt == 0)printf("All passed");
return 0;
}
1031 查验身份证(15 分)
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 题目信息 一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:首先对前17...