解释int checkID(char *ID) { int weight[18]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};//ID号码权重 char checkcode[11]={1,0,'X',9,8,7,6,5,4,3,2};//校验码字符 int sum=0;//加权和 int i; if(strlen(ID)!=18){ return 0; } for(i=0;i<17;i++){ if(!isdigit(ID[i])){//isdigit=? return 0; } } for(i=0;i<17;i++){ // sum+=ID[i]*weight[i]; sum+=(ID[i]-'0')*weight[i]; } int code; code=sum%11; if(ID[17]==checkcode[code]){ return 1; } else{ return 0; } }
时间: 2023-06-24 14:08:38 浏览: 45
这段代码是用来验证身份证号码是否合法的。它的实现原理是根据国家制定的身份证号码规则,对输入的身份证号码进行加权求和,并根据校验码判断其是否合法。具体来说,代码中定义了一个权重数组和一个校验码字符数组,分别用来表示身份证号码每一位的权重和校验码。然后,代码通过循环遍历身份证号码的每一位,计算其加权和。最后,代码根据计算出的校验码和输入身份证号码的校验码进行比较,判断身份证号码是否合法。
值得注意的是,代码中使用了isdigit函数来判断身份证号码中的字符是否为数字。isdigit函数是C语言标准库中的一个函数,用来判断一个字符是否为数字字符。如果是数字字符,则函数返回非0值;否则返回0。
相关问题
) int checkID(char *ID); (7分) 判别身份证校验位是否正确的函数。其中参数 ID 代表一个 18 位身份证号,如果校验位正确,函数返回 1,否则返回 0。
以下是一个简单的实现,用于判别身份证校验位是否正确:
```
int checkID(char *ID) {
int weight[] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
char checkCode[] = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};
int sum = 0;
for (int i = 0; i < 17; i++) {
sum += (ID[i] - '0') * weight[i];
}
int index = sum % 11;
return ID[17] == checkCode[index];
}
```
这个函数的实现基于以下的校验规则:
1. 前 17 位数字分别乘以对应的权重,然后求和。
2. 将上面的和除以 11 取余数,得到一个数字。
3. 根据余数查表得到一个校验码。
4. 如果身份证号的最后一位是上面得到的校验码,那么校验成功。
注意,这个实现并没有对输入的身份证号进行任何格式检查,比如说长度是否为 18 位,前 17 位是否都是数字等等。如果需要更严格的检查,可以在函数中加入相应的代码。
请解释一下int checkID(char id[]) { int i, sum = 0; int weight[] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2}; char check_code[] = "10X98765432"; for (i = 0; i < 17; i++) {sum += (id[i] - '0') * weight[i]; }int mod = sum % 11;char check = check
_code[mod];if (check == id[17]) {return 1;} else {return 0;}}
这是一个用来检验身份证号码是否合法的函数。函数接受一个身份证号码的字符数组作为输入参数,返回一个整型值,1 表示身份证号码合法,0 表示不合法。
函数的实现中,首先定义了一个 weight 数组,这个数组包含了身份证号码中每一位数字的权重值。然后定义了一个 check_code 字符数组,这个数组包含了身份证号码校验位的取值范围。接下来,使用一个 for 循环遍历身份证号码中的前 17 位数字,并根据权重值计算它们的加权和。计算加权和之后,使用 mod 运算符计算加权和除以11的余数,然后根据余数在 check_code 数组中查找对应的校验位。最后,将查找到的校验位与身份证号码中的第 18 位进行比较,如果相等则表示身份证号码合法,返回1;否则表示身份证号码不合法,返回0。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![doc](https://img-home.csdnimg.cn/images/20210720083327.png)
![docx](https://img-home.csdnimg.cn/images/20210720083331.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![doc](https://img-home.csdnimg.cn/images/20210720083327.png)