我国公民的身份证号码合法性判断
2014-04-13 12:06
393 查看
我国公民的身份证号码特点如下:
1、长度为18 位;
2、第1~17 位只能为数字;
3、第18 位可以是数字或者小写英文字母x。
4、身份证号码的第7~14 位表示持有人生日的年、月、日信息。
例如:511002198808080111 或51100219880808011x。
请实现身份证号码合法性判断的函数。除满足以上要求外,需要对持有人生日的年、月、日
信息进行校验。年份大于等于1900 年,小于等于2100 年。需要考虑闰年、大小月的情况。
所谓闰年,能被4 整除且不能被100 整除或能被400 整除的年份,闰年的2 月份为29 天,
非闰年的2 月份为28 天。其他情况的合法性校验,考生不用考虑。
函数返回值:
1) 如果身份证号合法,返回0;
2) 如果身份证号长度不合法,返回1;
3) 如果身份证号第1~17 位含有非数字的字符,返回2;
4) 如果身份证号第18 位既不是数字也不是英文小写字母x,返回3;
5) 如果身份证号的年信息非法,返回4;
6) 如果身份证号的月信息非法,返回5;
7) 如果身份证号的日信息非法,返回6(请注意闰年的情况);
【注】除成功的情况外,以上其他合法性判断的优先级依次降低。也就是说,如果判断出长
度不合法,直接返回1 即可,不需要再做其他合法性判断。
要求实现函数:
int verifyIDCard(char* input)
【输入】char* input,表示输入的身份证号码字符串
【输出】无
【返回】判断的结果,类型为int
示例
1) 输入:”511002111222”,函数返回值:1;
2) 输入:”511002abc123456789”,函数返回值:2;
3) 输入:”51100219880808123a”,函数返回值:3;
4) 输入:”511002188808081234”,函数返回值:4;
5) 输入:”511002198813081234”,函数返回值:5;
6) 输入:”511002198808321234”,函数返回值:6;
7) 输入:”511002198902291234”,函数返回值:6;【注】原题目是返回7,但是没有说明合适返回7,所以应该是打印错误,所以就斗胆将此处7改为6
8) 输入:”511002198808081234”,函数返回值:0;
#include <stdio.h>
#include <string.h>
int verifyIDCard(char *input){
int dayOfMon[] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
int i;
int len = strlen(input);
int year, month, day;
if(len != 18) return 1;//长度不合法
for(i = 0; i < len -1; i++){
if(input[i] < '0' || input[i] > '9') return 2;//前17位,含有非数字字符
}
if(!(((input[17] >= '0') && (input[17] <= '9')) || (input[17] == 'z'))) return 3;//最后一位既不是数字又不是‘z’
if ( !(((input[i] > '0') && ( input[i] < '9')) || ( ((input[i] > 'A' ) && ( input[i] < 'Z')) || ((input[i] > 'a' ) && ( input[i] < 'z')) ) ) ) return 4;
year = (input[6] - '0') * 1000 + (input[7] - '0') * 100 + (input[8] - '0') * 10 + (input[9] - '0');
if(year < 1900 || year > 2100) return 4;
month = (input[10] - '0')*10 + input[11] - '0';
if(month < 1 || month > 12) return 5;
day = (input[12] - '0')*10 + (input[13] - '0');
if((year % 400 == 0) || ((year % 100 != 0) && (year % 4 ==0))){
if(day < 1|| day >= (dayOfMon[month - 1] + 1)) return 6;
}else if (day < 1 || day >= (dayOfMon[month - 1])) return 6;
return 0;
}
void main(){
char ID[8][50];
strcpy(ID[0], "511002111222");
printf("%s", ID[0]);
printf("\tresult:\t%d\n", verifyIDCard(ID[0]));
strcpy(ID[1], "511002abc123456789");
printf("%s", ID[1]);
printf("\tresult:\t%d\n", verifyIDCard(ID[1]));
strcpy(ID[2], "51100219880808123a");
printf("%s", ID[2]);
printf("\tresult:\t%d\n", verifyIDCard(ID[2]));
strcpy(ID[3], "511002188808081234");
printf("%s", ID[3]);
printf("\tresult:\t%d\n", verifyIDCard(ID[3]));
strcpy(ID[4], "511002198813081234");
printf("%s", ID[4]);
printf("\tresult:\t%d\n", verifyIDCard(ID[4]));
strcpy(ID[5], "511002198808321234");
printf("%s", ID[5]);
printf("\tresult:\t%d\n", verifyIDCard(ID[5]));
strcpy(ID[6], "511002198902291234");
printf("%s", ID[6]);
printf("\tresult:\t%d\n", verifyIDCard(ID[6]));
strcpy(ID[7], "511002198808081234");
printf("%s", ID[7]);
printf("\tresult:\t%d\n", verifyIDCard(ID[7]));
getchar();
}
1、长度为18 位;
2、第1~17 位只能为数字;
3、第18 位可以是数字或者小写英文字母x。
4、身份证号码的第7~14 位表示持有人生日的年、月、日信息。
例如:511002198808080111 或51100219880808011x。
请实现身份证号码合法性判断的函数。除满足以上要求外,需要对持有人生日的年、月、日
信息进行校验。年份大于等于1900 年,小于等于2100 年。需要考虑闰年、大小月的情况。
所谓闰年,能被4 整除且不能被100 整除或能被400 整除的年份,闰年的2 月份为29 天,
非闰年的2 月份为28 天。其他情况的合法性校验,考生不用考虑。
函数返回值:
1) 如果身份证号合法,返回0;
2) 如果身份证号长度不合法,返回1;
3) 如果身份证号第1~17 位含有非数字的字符,返回2;
4) 如果身份证号第18 位既不是数字也不是英文小写字母x,返回3;
5) 如果身份证号的年信息非法,返回4;
6) 如果身份证号的月信息非法,返回5;
7) 如果身份证号的日信息非法,返回6(请注意闰年的情况);
【注】除成功的情况外,以上其他合法性判断的优先级依次降低。也就是说,如果判断出长
度不合法,直接返回1 即可,不需要再做其他合法性判断。
要求实现函数:
int verifyIDCard(char* input)
【输入】char* input,表示输入的身份证号码字符串
【输出】无
【返回】判断的结果,类型为int
示例
1) 输入:”511002111222”,函数返回值:1;
2) 输入:”511002abc123456789”,函数返回值:2;
3) 输入:”51100219880808123a”,函数返回值:3;
4) 输入:”511002188808081234”,函数返回值:4;
5) 输入:”511002198813081234”,函数返回值:5;
6) 输入:”511002198808321234”,函数返回值:6;
7) 输入:”511002198902291234”,函数返回值:6;【注】原题目是返回7,但是没有说明合适返回7,所以应该是打印错误,所以就斗胆将此处7改为6
8) 输入:”511002198808081234”,函数返回值:0;
#include <stdio.h>
#include <string.h>
int verifyIDCard(char *input){
int dayOfMon[] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
int i;
int len = strlen(input);
int year, month, day;
if(len != 18) return 1;//长度不合法
for(i = 0; i < len -1; i++){
if(input[i] < '0' || input[i] > '9') return 2;//前17位,含有非数字字符
}
if(!(((input[17] >= '0') && (input[17] <= '9')) || (input[17] == 'z'))) return 3;//最后一位既不是数字又不是‘z’
if ( !(((input[i] > '0') && ( input[i] < '9')) || ( ((input[i] > 'A' ) && ( input[i] < 'Z')) || ((input[i] > 'a' ) && ( input[i] < 'z')) ) ) ) return 4;
year = (input[6] - '0') * 1000 + (input[7] - '0') * 100 + (input[8] - '0') * 10 + (input[9] - '0');
if(year < 1900 || year > 2100) return 4;
month = (input[10] - '0')*10 + input[11] - '0';
if(month < 1 || month > 12) return 5;
day = (input[12] - '0')*10 + (input[13] - '0');
if((year % 400 == 0) || ((year % 100 != 0) && (year % 4 ==0))){
if(day < 1|| day >= (dayOfMon[month - 1] + 1)) return 6;
}else if (day < 1 || day >= (dayOfMon[month - 1])) return 6;
return 0;
}
void main(){
char ID[8][50];
strcpy(ID[0], "511002111222");
printf("%s", ID[0]);
printf("\tresult:\t%d\n", verifyIDCard(ID[0]));
strcpy(ID[1], "511002abc123456789");
printf("%s", ID[1]);
printf("\tresult:\t%d\n", verifyIDCard(ID[1]));
strcpy(ID[2], "51100219880808123a");
printf("%s", ID[2]);
printf("\tresult:\t%d\n", verifyIDCard(ID[2]));
strcpy(ID[3], "511002188808081234");
printf("%s", ID[3]);
printf("\tresult:\t%d\n", verifyIDCard(ID[3]));
strcpy(ID[4], "511002198813081234");
printf("%s", ID[4]);
printf("\tresult:\t%d\n", verifyIDCard(ID[4]));
strcpy(ID[5], "511002198808321234");
printf("%s", ID[5]);
printf("\tresult:\t%d\n", verifyIDCard(ID[5]));
strcpy(ID[6], "511002198902291234");
printf("%s", ID[6]);
printf("\tresult:\t%d\n", verifyIDCard(ID[6]));
strcpy(ID[7], "511002198808081234");
printf("%s", ID[7]);
printf("\tresult:\t%d\n", verifyIDCard(ID[7]));
getchar();
}
相关文章推荐
- 华为机试题:身份证号码合法性判断
- 华为2011软件开发校园测试机试题--身份证号码合法性判断
- 身份证号码合法性判断
- java语言利用正则表达式判断身份证号码合法性
- 字符串处理算法(七)身份证号码合法性判断(华为校园招聘题)
- 身份证号码的合法性判断
- 身份证号码合法性判断
- Oracle根据身份证号码判断性别
- 公民的身份证号码检测
- 身份证号码的合法性校验
- 手机号码合法性判断
- 华为机试——判断手机号码合法性
- iOS 判断身份证号码
- 身份证号码合法性验证
- 华为:请实现手机号码合法性判断的函数
- JS实现中国公民身份证号码有效性验证
- 手机号码合法性判断
- Android(Java)正则表达式判断手机号、邮箱、身份证号码、密码、Url、邮编等工具类
- javascript或asp实现的判断身份证号码是否正确两种验证方法
- 关于手机号码合法性判断