问题描写叙述:
我国公民的身份证号码特点例如以下:
1、长度为18位。
2、第1~17位仅仅能为数字。
3、第18位能够是数字或者小写英文字母x。
4、身份证号码的第7~14位表示持有人生日的年、月、日信息。
比如:511002198808080111或51100219880808011x。
请实现身份证号码合法性推断的函数。除满足以上要求外,须要对持有人生日的年、月、日信息进行校验。年份大于等于1900年,小于等于2100年。须要考虑闰年、大小月的情况。所谓闰年,能被4整除且不能被100整除或能被400整除的年份,闰年的2月份为29天,非闰年的2月份为28天。其它情况的合法性校验,考生不用考虑。
执行结果例如以下:
我国公民的身份证号码特点例如以下:
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)
演示样例
1、输入:”511002111222”。函数返回值:1;
2、输入:”511002abc123456789”,函数返回值:2;
3、输入:”51100219880808123a”,函数返回值:3;
4、输入:”511002188808081234”,函数返回值:4;
5、输入:”511002198813081234”,函数返回值:5。
6、输入:”511002198808321234”,函数返回值:6。
7、输入:”511002198902291234”,函数返回值:6;
8、输入:”511002198808081234”。函数返回值:0;
C代码例如以下:
#include<stdio.h> #include<stdlib.h> #include<string.h> int verifyIDCard(char* input); int is_leapyear(int year); int getyear(char* input); int getmonth(char* input); int getday(char* input); int check_1to17(char* input); int check18(char* input); int chech_year_month_day(int year, int month, int day); int main() { char input[8][100] = {"511002111222","511002abc123456789", "51100219880808123a","511002188808081234","511002198813081234", "511002198808321234","511002198902291234","511002198808081234"}; int i; for(i=0; i<8; i++) { printf("the IDcard is: %s, the result is: %d ",input[i],verifyIDCard(input[i])); } return 0; } int is_leapyear(int year) { if(( (year%4==0) && (year%400!=0) ) || (year%400==0)) return 1; return 0; } int getyear(char* input) { int year=0; year = (input[6]-'0') * 1000 + (input[7]-'0') * 100 + (input[8]-'0') * 10 + (input[9]-'0'); return year; } int getmonth(char* input) { int month=0; month = (input[10]-'0') * 10 + (input[11]-'0'); return month; } int getday(char* input) { int day=0; day = (input[12]-'0') * 10 + (input[13]-'0'); return day; } int check_1to17(char* input) { int i; for(i=0; i<17; i++) if( !(input[i]>='0' && input[i]<='9') ) return 0; return 1; } int check18(char* input) { char ch = input[17]; if( (ch=='x') || (ch>='0' && ch<='9') ) return 1; else return 0; } int check_year_month_day(int year, int month, int day) { int leap; leap = is_leapyear(year); if(year<1900 || year>2100) return 4; if(month<1 || month>12) return 5; switch(month) { case 1: case 3: case 5: case 7: case 8: case 10: case 12: { if(day<1 || day>31) return 6; break; } case 4: case 6: case 9: case 11: { if(day<1 || day>30) return 6; break; } case 2: { if(leap) { if(day<1 || day>29) return 6; break; } else { if(day<1 || day>28) return 6; break; } } } return 0; } int verifyIDCard(char* input) { int year,month,day; if(strlen(input)!=18) return 1; else { if(!check_1to17(input)) return 2; else { if(!check18(input)) return 3; else { year = getyear(input); month = getmonth(input); day = getday(input); return check_year_month_day(year,month,day); } } } }
执行结果例如以下: