c语言复习大坑,作业:身份证校验

来源:互联网 发布:汽车防盗芯片编程器 编辑:程序博客网 时间:2024/04/28 07:52

我个坑货,作业贴到这吧。


身份证的构成:

1.地址码
  (身份证前六位)表示编码对象常住户口所在县(市、旗、区)的行政区划代码。
2.生日期码
  (身份证第七位到第十四位)表示编码对象出生的年、月、日,其中年份用四位数字表示,年、月、日之间不用分隔符。例如:1981年05月11日就用19810511表示。
3. 顺序码
  (身份证第十五位到十七位)为同一地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号。其中第十七位奇数分给男性,偶数分给女性。
4.校验码
(身份证最后一位)是根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。作为尾号的校验码,是由号码编制单位按统一的公式计算出来的,如果某人的尾号是0-9,都不会出现X,但如果尾号是10,那么就得用X来代替,因为如果用10做尾号,那么此人的身份证就变成了19位,而19位的号码违反了国家标准,并且我国的计算机应用系统也不承认19位的身份证号码。Ⅹ是罗马数字的10,用X来代替10,可以保证公民的身份证符合国家标准。

★ISO 7064:1983.MOD 11-2校验码计算:

按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。 第十八位数字的计算方法为:

1.将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2
2.将这17位数字和系数相乘的结果相加。
3.用加出来和除以11,看余数是多少?
4余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字。其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2。
5.通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的Ⅹ。如果余数是10,身份证的最后一位号码就是2。
  sos !!!用c语言编写一程序验证身份证是否合法的程序,规则和要求如上 各位帮帮忙。。。例如:某男性的身份证号码是34052419800101001X。


我写的:

#include<stdio.h>#include<stdlib.h>#define Y {printf("校验通过!\n");break;}#define N {printf("校验失败,号码非法!\n");break;}int main() { char a[19];int b[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};int i=0,tmp=0,x;while(scanf("%s",a)!=EOF){tmp=0;if (a[18]!='\0') {printf("错误,号码不足18位\n");continue;}//略去出生日期、性别判断for (i=0;i<17;i++)tmp+=((int)a[i]-48)*b[i];x=tmp%11;switch(x){case 0:{if (a[17]=='1') Y else N};case 1:{if (a[17]=='0') Y else N};case 2:{if (a[17]=='X') Y else N};case 3:{if (a[17]=='9') Y else N};case 4:{if (a[17]=='8') Y else N};case 5:{if (a[17]=='7') Y else N};case 6:{if (a[17]=='6') Y else N};case 7:{if (a[17]=='5') Y else N};case 8:{if (a[17]=='4') Y else N};case 9:{if (a[17]=='3') Y else N};case 10:{if (a[17]=='2') Y else N};default: N}}system("pause");return 0;}



原创粉丝点击