身份证号码检测

华为的上机题

我国公民的身份证号码特点如下:
1、 长度为18位;
2、 第1~17位只能为数字;
3、 第18位可以是数字或者小写英文字母x。
4、 身份证号码的第7~14位表示持有人生日的年、月、日信息。
例如:511002 19880808 0111或511002 19880808011x。
请实现身份证号码合法性判断的函数。除满足以上要求外,需要对持有人生日的
年、月、日信息进行校验。年份大于等于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) 输入:”511002 111222”,函数返回值:1;
2) 输入:”511002 abc123456789”,函数返回值:2;
3) 输入:”511002 19880808123a”,函数返回值:3;
4) 输入:”511002 188808081234”,函数返回值:4;
5) 输入:”511002 198813081234”,函数返回值:5;
6) 输入:”511002 198808321234”,函数返回值:6;
7) 输入:”511002 1989 0229 1234”,函数返回值:7;
8) 输入:”511002 198808081234”,函数返回值:0;

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int verifyIDCard(char* input)   
{   
    if (strlen(input) != 18)   
        return 1;   
	
    for(int i=0;i<17;i++)   
    {   
        if(input[i] < '0' || input[i] > '9')   
            return 2;   
    }   
	
    if(input[17] == 'x' || (input[17]>='0' && input[17]<= '9'));   
    else   
        return 3;   
	
    char year[5];   
    year[0] = input[6];   
    year[1] = input[7];   
    year[2] = input[8];   
    year[3] = input[9];   
    year[4] = '\0';   
    int year_num = atoi(year);   
    if(year_num <= 1900 || year_num >= 2100)   
        return 4;   
	
    char month[3];   
    month[0] = input[10];   
    month[1] = input[11];   
    month[2] = '\0';   
    int month_num = atoi(month);   
    if(month_num > 12 || month_num < 1)   
        return 5;   
	
    char day[3];   
    day[0] = input[12];   
    day[1] = input[13];   
    day[2] = '\0';   
    int day_num = atoi(day);   
    if(((year_num % 4 == 0) && (year_num % 100 != 0)) || (year_num % 400 == 0))     // 闰年   
    {   
        if(month_num == 2)   
        {   
            if(day_num < 1 || day_num > 29)   
                return 6;   
        }   
        else if(month_num == 1 || month_num == 3 ||month_num == 5 ||month_num == 7 ||month_num == 8 ||month_num == 10 ||month_num == 12)   
        {   
            if(day_num < 1 || day_num > 31)   
                return 6;   
        }   
        else   
        {   
            if(day_num < 1 || day_num > 30)   
                return 6;   
        }   
    }   
    else        // 不是闰年   
    {   
        if(month_num == 2)   
        {   
            if(day_num < 1 || day_num > 28)   
                return 6;   
        }   
        else if(month_num == 1 || month_num == 3 ||month_num == 5 ||month_num == 7 ||month_num == 8 ||month_num == 10 ||month_num == 12)   
        {   
            if(day_num < 1 || day_num > 31)   
                return 6;   
        }   
        else   
        {   
            if(day_num < 1 || day_num > 30)   
                return 6;   
        }   
    }   
	
    return 0;  
}

void main()
{
	char id[50];
	int result;
	printf("please input a ID number:\n");
	scanf("%s",&id);
	//printf("%s\n",id);
	result=verifyIDCard(id);
	printf("%d\n",result);
}



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值