C语言程序设计—北京理工大学MOOC提交作业(1) 下载本文

5、校验码

(1)十七位数字本体码加权求和公式

S = Sum(Ai * Wi), i = 0, ... , 16 ,先对前17位数字的权求和 Ai: 表示第i位置上的身份证号码数字值 Wi: 表示第i位置上的加权因子

Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 (2)计算模

Y = mod(S, 11) Y = S % 11 (3)通过模得到对应的校验码 Y: 0 1 2 3 4 5 6 7 8 9 10 校验码: 1 0 X 9 8 7 6 5 4 3 2

四、举例如下:

北京市朝阳区: 11010519491231002X 广东省汕头市: 440524188001010014 15位的身份证号升级办法:

15位的身份证号:dddddd yymmdd xx p 18位的身份证号:dddddd yyyymmdd xx p y

o 其中dddddd为地址码(省地县三级) o yyyymmdd yymmdd 为出生年月日 o xx顺号类编码 o p性别

15 位的 yy 年升为 18 位后,变成 19yy年,但对于百岁以上老人, 则为 18yy 年,此时,他们的最后三位顺序码为996, 997, 998 或 999 来标记。

输入

输入n组身份证号码,第一行为个数,以后每行为身份证号码。

输出

如果输入的身份证号码为15位,则将其升级为18位后显示输出;否则判断其是否为合法身份证号,并逐行输出。

测试输入 期待的输出 时间限制 内存限制 64M 额外进程 0 测试用例 1 以文本方式显示 1. 2. 3. 4. 5. 4? 350622197904130331? 11010519491231002X? 110105491231002? 110105491231996? 以文本方式显示 1. 2. 3. 4. Invalid? Valid? 11010519491231002X? 110105184912319965? 1秒 Code:

#include #include int main() { int n, i, m, j, sumt, y; char s[100][19], temp[19], t; scanf(\ for(i = 0; i < n; i++) scanf(\ for(i = 0; i < n; i++) { m = 0; while(s[i][m] != '\\0') { m++; } if( m != 15 && m != 18) { printf(\ } if( m == 15) { for(j = 0; j < 6; j++) temp[j] = s[i][j]; if(s[i][12] == '9' && s[i][13] == '9' && s[i][14] > '5') { temp[6] = '1'; temp[7] = '8'; }

else { temp[6] = '1'; temp[7] = '9'; } for(j = 6; j < 16; j++) temp[j + 2] = s[i][j]; strcpy(s[i],temp); sumt = (s[i][0] - '0') * 7 + (s[i][1]- '0') * 9 + (s[i][2] - '0') * 10 + (s[i][3] - '0') * 5 + (s[i][4] - '0') * 8 + (s[i][5] - '0') * 4 + (s[i][6]-'0') * 2 + (s[i][7]-'0') * 1 + (s[i][8]-'0') * 6 + (s[i][9]-'0') * 3 + (s[i][10]-'0') * 7 + (s[i][11]-'0') * 9 + (s[i][12]-'0') * 10 + (s[i][13]-'0') * 5 + (s[i][14]-'0') * 8 + (s[i][15]-'0') * 4 + (s[i][16]-'0') * 2; //sumt = atoi(s[i][0]) * 7 + atoi(s[i][1]) * 9 + atoi(s[i][2]) * 10 + atoi(s[i][3]) * 5 +atoi(s[i][4]) * 8 + atoi(s[i][5]) * 4 + atoi(s[i][6]) * 2 + atoi(s[i][7]) * 1 + atoi(s[i][8]) * 6 + atoi(s[i][9]) * 3 + atoi(s[i][10]) * 7 + atoi(s[i][11]) * 9 + atoi(s[i][12]) * 10 + atoi(s[i][13]) * 5 + atoi(s[i][14]) * 8 + atoi(s[i][15]) * 4 + atoi(s[i][16]) * 2; y = sumt % 11; switch (y) { case 0: s[i][17] = '1'; break; case 1: s[i][17] = '0'; break; case 2: s[i][17] = 'X'; break; case 3: s[i][17] = '9'; break; case 4: s[i][17] = '8'; break; case 5: s[i][17] = '7'; break; case 6: s[i][17] = '6'; break; case 7: s[i][17] = '5'; break; case 8: s[i][17] = '4'; break; case 9: s[i][17] = '3'; break; case 10: s[i][17] = '2'; break; } s[i][18] = '\\0'; printf(\ } if(m == 18) { sumt = (s[i][0] - '0') * 7 + (s[i][1]- '0') * 9 + (s[i][2] - '0') * 10 + (s[i][3] - '0') * 5 + (s[i][4] - '0') * 8 + (s[i][5] - '0') * 4 + (s[i][6]-'0') * 2 + (s[i][7]-'0') * 1 + (s[i][8]-'0') * 6 + (s[i][9]-'0') * 3 + (s[i][10]-'0') * 7 + (s[i][11]-'0') * 9 + (s[i][12]-'0') * 10 + (s[i][13]-'0') * 5 + (s[i][14]-'0') * 8 + (s[i][15]-'0') * 4 + (s[i][16]-'0') * 2; y = sumt % 11; switch (y) { case 0: t = '1'; break; case 1: t = '0'; break;

}

case 2: t = 'X'; break; case 3: t = '9'; break; case 4: t = '8'; break; case 5: t = '7'; break; case 6: t = '6'; break; case 7: t = '5'; break; case 8: t = '4'; break; case 9: t = '3'; break; case 10: t = '2'; break; } if(t == s[i][17]) printf(\ else printf(\ } }

return 0;

4.安全的密码(选做)

成绩 折扣 0 开启时间 2014年11月27日 星期四 03:10 0.8 折扣时间 2014年12月10日 星期三 03:10 关闭时间 2014年12月17日 星期三 03:10 允许迟交 否 随着电子设备的广泛运用,密码也渐渐融入每个人的生活。保护好密码,不仅关系到个人隐私,更关系到个人的财产和安全。一个安全的密码,最好由大小写字母、数字或符号组成。包含越多种类的字符,其安全性就越高。同时密码还需要有一定的长度,通常至少要由六个以上的字符组成。

并不是每个人都喜欢这样复杂的密码,很多人在设置密码的时候,喜欢使用自己的名字或者生日,但这是很大的安全隐患。

任务

林晓炜正在设计一个网络交易系统,为了保证用户的密码安全,他需要一个程序,判断用户自己设置的密码是否安全,如果不安全,则给出提示。现在他向你求助,请你帮忙设计一个程序来解决这个问题。

应当按照以下的规则来判断密码是否安全: 1. 如果密码长度小于 6 位,则不安全

2. 如果组成密码的字符只有一类,则不安全 3. 如果组成密码的字符有两类,则为中度安全