如果已经知道一个人的身份证前17位,可以通过如下步骤得到第18位:
第一步:将前面的身份证号码17位数分别乘以不同的系数,从第一位到第十七位的系数分别为:7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2。
第二步:将这17位数字和系数相乘的结果相加。
第三步:用相加结果除以11,得出余数。
第四步:余数只可能有0-1-2-3-4-5-6-7-8-9-10这11个数字。其分别对应的最后一位身份证的号码为1-0-X-9-8-7-6-5-4-3-2(专门生成一个match数组存放)
#include <stdio.h>
#include <stdlib.h>
void main()
{
int a[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2},sum=0,i;
char b[19];//数组长度比身份证长度多1用于放‘\0’
char match[11]={'1','0','x','9','8','7','6','5','4','3','2'};
gets(b);
for(i=0;i<17;i++)
sum+=(b[i]-'0')*a[i];
if(match[sum%11]==b[17])
printf("correct,出生年月为:%c%c%c%c年%d月%d日",b[6],b[7],b[8],b[9],(b[10]-'0')*10+b[11]-'0',(b[12]-'0')*10+b[13]-'0');
else
printf("wrong");
}