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

内容发布更新时间 : 2025/7/27 2:46:37星期一 下面是文章的全部内容请认真阅读。

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'

>>展开全文<<
12@gma联系客服:779662525#qq.com(#替换为@) 苏ICP备20003344号-4 ceshi