按照以下所给方法写出下列C语言结构体程序并注释 int checkID(char *ID); (7分) 判别身份证校验位是否正确的函数。其中参数 ID 代表一个 18 位身份证号,如果校验位正确,函数返回 1,否则返回 0。方法:校验位产生办法 如果已经知道一个人的身份证前17位,可以通过如下步骤得到第18位: (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,这就是身份证号码的校验位。
时间: 2024-04-06 17:32:54 浏览: 48
```
// 定义结构体
struct IDCard {
char ID[18]; // 身份证号
};
// 校验身份证号码
int checkID(char *ID) {
int i, sum = 0;
int factors[17] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
char checkCodes[11] = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};
for (i = 0; i < 17; i++) {
sum += (ID[i] - '0') * factors[i];
}
return checkCodes[sum % 11] == ID[17];
}
```
注释:
- 第1行:定义了一个名为 IDCard 的结构体,其中包含一个长度为 18 的字符数组 ID,用于存储身份证号码。
- 第3行:定义了一个名为 checkID 的函数,接收一个 char* 类型的参数 ID,代表一个 18 位身份证号。
- 第4行:定义了两个 int 类型的变量 i 和 sum,其中 i 用于循环计数,sum 用于计算身份证号码前17位的加权和。
- 第5行:定义了一个长度为 17 的 int 类型数组 factors,用于存储每一位身份证号码对应的加权因子。
- 第6行:定义了一个长度为 11 的字符数组 checkCodes,用于存储身份证号码校验位对应的字符。
- 第7行:使用 for 循环,将前17位身份证号码分别乘以对应的加权因子,然后累加到 sum 变量中。
- 第8行:使用模运算,计算出校验位对应的字符,并将其与身份证号码的最后一位进行比较。
- 第9行:如果校验位正确,返回 1;否则返回 0。
阅读全文