华为机试——身份证号码合法性
2016-01-08 15:14
267 查看
题目:身份证号码合法性判断(2012)
问题描述:
我国公民的身份证号码特点如下:
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”,函数返回值:7;
8) 输入:”511002198808081234”,函数返回值:0;
#include<iostream> #include<cstring> #include<cctype> #include<string> using namespace std; int verifyIDCard(char* input) { int len=strlen(input); int i; char year[5],month[3],day[3]; if(len!=18) return 1; for(i=0;i<17;i++) { if(!isdigit(input[i])) { return 2; } } if(!isdigit(input[17]) && input[17]!='x') return 3; 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; month[0]=input[10]; month[1]=input[11]; month[2]='\0'; int month_num=atoi(month); if(month_num<1 || month_num>12) return 5; day[0]=input[12]; day[1]=input[13]; day[2]='\0'; int day_num=atoi(day); if(day_num<=0 || day_num>31) return 6; if((year_num%4==0 && year_num%100 !=0) || (year_num % 400==0)) //闰年 { if((month_num==2)&&(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)&&(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; } int main() { char str[30]; cin.get(str,30); cout<<verifyIDCard(str)<<endl; }
相关文章推荐
- maven环境搭建(Windows)
- 操作xml文档的常用方式
- C#设计模式前奏-面向对象设计原则
- Html5添加支持桌面、移动触摸手机和平板电脑的Lightbox插件教程
- Javascript关闭Chrome等所有浏览器的方法
- Android Fragment详解(二):fragment创建及其生命周期
- 如何用命令行制作U盘启动器重装系统
- LeetCode:Permutations
- Linux - centOS 学习小记
- Eclipse Java注释模板设置详解
- 隐藏应用图标。
- 一则浮点计算异常的处理随笔
- GpsLocationProvider中的sendExtraCommand方法
- 个人记录一些常用的知识点
- LeetCode_237. Delete Node in a Linked List
- 什么是扇入和扇出?
- 用C语言实现对bmp格式图片打码(附源码)
- 谷歌浏览器开发调试工具中Sources面板 js调试等 完全介绍
- Lighttpd1.4.20源码分析 笔记 网络服务主模型
- 从头认识java-17.2 基本的线程机制(2)-Executors的使用