身份证规则详细讲解

身份证规则详细讲解

提示:首先说明一下二代身份证的规则
18位身份证验证
* 根据〖中华人民共和国国家标准 GB 11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。
* 排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
* 第十八位数字(校验码)的计算方法为:
* 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。

支持!务必点赞哟!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我来给您讲解一下。 首先,我们需要明确一下身份证号码的校验规则身份证号码的最后一位是校验位,是根据前面 17 位计算得出的。具体的计算方法是: 1. 将身份证号码前 17 位分别乘以对应的系数(系数从左到右依次为:7、9、10、5、8、4、2、1、6、3、7、9、10、5、8、4、2)。 2. 将上述结果相加得到一个数。 3. 用上述结果除以 11,得到的余数就是校验位对应的数字。余数为 0 则校验位为 1,余数为 1 则校验位为 0,余数为 2 则校验位为 X,余数为 3~10 则校验位为对应的数字(例如余数为 3,则校验位为 3)。 接下来,我们就可以根据上述规则来写代码了。具体的实现方式是:将身份证号码前 17 位分别存入一个结构体中的数组中,并定义一个指向该结构体的指针,然后编写一个函数 checkID,该函数接受一个 char 类型的指针作为参数,指向身份证号码的字符串,返回值为 int 类型,表示校验位是否正确。 下面是代码实现及注释: ```c #include <stdio.h> struct ID { int num[17]; // 存储身份证号码前 17 位 }; int checkID(char *ID) { int i, sum = 0, mod; // sum 存储前 17 位乘以系数后的结果之和,mod 存储 sum 对 11 取余的结果 struct ID id; // 定义一个 ID 类型的结构体 int *p = id.num; // 定义一个指向 id.num 数组的指针 // 将身份证号码前 17 位转换成数字并存储到 id.num 数组中 for (i = 0; i < 17; i++) { *(p + i) = *(ID + i) - '0'; } // 计算前 17 位乘以系数后的结果之和 for (i = 0; i < 17; i++) { sum += *(p + i) * (i % 2 == 0 ? 7 : (i % 2 == 1 ? 9 : 0)); } // 计算 sum 对 11 取余的结果 mod = sum % 11; // 判断校验位是否正确并返回相应的值 if (mod == 0 && *(ID + 17) == '1') { return 1; } else if (mod == 1 && *(ID + 17) == '0') { return 1; } else if (mod == 2 && *(ID + 17) == 'X') { return 1; } else if (mod >= 3 && mod <= 10 && *(ID + 17) == mod + '0') { return 1; } else { return 0; } } int main() { char ID[18] = "11010119900307663X"; // 测试用的身份证号码 if (checkID(ID)) { printf("校验位正确!\n"); } else { printf("校验位错误!\n"); } return 0; } ``` 希望对您有所帮助!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值