问题描写叙述:
我国公民的身份证号码特点例如以下:
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\n",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);
}
}
}
}
执行结果例如以下: