我国公民的身份证号码合法性判断

我国公民的身份证号码特点如下:
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();
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值