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

2020-03-27 19:43

}

//将每行的最大值放入每行的最后; for(y = 0; y < m; y++) { temp = 0; for(x = 0; x < n; x++) { if(i[y][x] > temp) temp = i[y][x]; } i[y][n] = temp; }

//将每列的最小值放入每列的最后 for(x = 0; x < n; x++) { temp = 0x7fffffff; for(y = 0; y < m; y++) { if(i[y][x] < temp) temp = i[y][x]; } i[m][x] = temp; }

for(y = 0; y < m; y++) { for(x = 0; x < n; x++) { if((i[y][x] == i[m][x]) && (i[y][x] == i[y][n])) {printf(\ } }

if(log == 0) printf(\return 0;

3.身份证的奥秘

成绩 折扣 10 开启时间 2014年11月27日 星期四 03:05 0.8 折扣时间 2014年12月10日 星期三 03:05 允许迟交 否 关闭时间 2014年12月17日 星期三 03:05 背景

18位身份证标准在国家质量技术监督局于1999年7月1日实施的GB11643-1999《公民身份号码》中做了明确的规定。 GB11643-1999《公民身份号码》为GB11643-1989《社会保障号码》的修订版,其中指出将原标准名称\社会保障号码\更名为\公民身份号码\,另外GB11643-1999《公民身份号码》从实施之日起代替GB11643-1989。GB11643-1999《公民身份号码》主要内容如下:

一、范围

该标准规定了公民身份号码的编码对象、号码的结构和表现形式,使每个编码对象获得一个唯一的、不变的法定号码。

二、编码对象

公民身份号码的编码对象是具有中华人民共和国国籍的公民。

三、号码的结构和表示形式

1、号码的结构

公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。

2、地址码

表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。

3、出生日期码

表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。

4、顺序码

表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。

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;


C语言程序设计—北京理工大学MOOC提交作业(1)(7).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:南开大学13春学期《管理伦理》在线作业(100分答案)

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: