L1-016 查验身份证
思路
刚看这题的时候有点懵了,没看懂这题目是啥意思,便去百度搜了下。
1.就是将身份证号码的前17位分别和权值相乘,再相加。(还要判断前17是否都为数字)
2.将所得的和再求余11
3.所得的数作为下标,用M与身份证最后一位验证码判定,若相等则真确,若不等则错误。
源码
#include <stdio.h>
#include<string.h>
int main(){
int weight[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
char view[18];
char M[11]={'1','0','X','9','8','7','6','5','4','3','2'};
int N=0,sum=0,flag=0,n=0;
scanf("%d",&N);
for(int i=0;i<N;i++){
sum=0;
scanf("%s",view);
for(int j=0;j<17;j++){
sum+=(view[j]-'0')*weight[j];
}
n=sum%11;
if(view[17]!=M[n]){
flag=1;
printf("%s\n",view);
}
}
if(flag==0) printf("All passed\n");
return 0;
}