zoukankan      html  css  js  c++  java
  • 身份证号码识别

    我国公民的身份证号码特点如下:

    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;

    8) 输入:”511002198808081234”,函数返回值:0;

     1 #include<stdio.h>
     2 #include<string.h>
     3 int verifyIDCard(char* input)
     4 {
     5     int sum,i,len,year,month,day;
     6     const char *p = input;
     7     len = strlen(p);
     8     if (len != 18)
     9         return 1;
    10     i = 0;
    11     while(i < 17)
    12     {
    13         if (p[i] < '0' || p[i] > '9')
    14             return  2;
    15         i++;
    16     }
    17     if ((p[i] < '0' || p[i] > '9') && p[i] != 'x')
    18         return 3;
    19     sum = 0;
    20     for (i=6; i < 10; i++)
    21     {
    22         int k = p[i] - '0';
    23         sum = sum * 10 + k;
    24     }
    25     year = sum;
    26     sum = 0;
    27     for (i=10; i < 12; i++)
    28     {
    29         int k = p[i] - '0';
    30         sum = sum * 10 + k;
    31     }
    32     month = sum;
    33     sum = 0;
    34     for (i=12; i < 14; i++)
    35     {
    36         int k = p[i] - '0';
    37         sum = sum * 10 + k;
    38     }
    39     day = sum;
    40     if (year > 2100 || year < 1900)
    41         return 4;
    42     if (month < 1 || month > 12)
    43         return 5;
    44     if (day < 1 || day > 31)
    45         return 6;
    46     if ((year % 400 == 0) || ((year % 4 == 0) && (year % 100 != 0)))
    47     {
    48         if (month == 2 && day > 29)
    49             return 6;
    50         if(month == 4 || month == 6 || month == 9 || month == 11)
    51             if (day > 30)
    52                 return 6;
    53     }
    54     else
    55     {
    56         if (month == 2 && day > 28)
    57             return 6;
    58         if(month == 4 || month == 6 || month == 9 || month == 11)
    59             if (day > 30)
    60                 return 6;
    61     }
    62     return 0;
    63 
    64 }
    65 int main()
    66 {
    67     char s[30];
    68     while(scanf("%s",s)){
    69         printf("%d
    ",verifyIDCard(s));
    70     }
    71 }

  • 相关阅读:
    当···时发生了什么?
    数据存储-3、数据库分库分表思路
    数据存储-2、反模式设计
    数据存储-1、MySQL 索引使用的注意事项
    锁机制-4、synchronized 与 lock 的区别
    锁机制-3、synchronize 实现原理
    锁机制-1、乐观锁与悲观锁以及乐观锁的一种实现方式
    线程-11、线程的生命周期
    线程-10、线程池的几种方式
    线程-9、线程池的实现原理
  • 原文地址:https://www.cnblogs.com/george-cw/p/3943878.html
Copyright © 2011-2022 走看看