公民的身份证号码检测
来源:互联网 发布:台湾数据库 编辑:程序博客网 时间:2024/05/01 13:39
我国公民的身份证号码特点如下:
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(请注意闰年的情况
#include <iostream>
#include <stdio.h>
#include <string>
using namespace std;
int isValid(const char *str)
{
int year = 0, month = 0, day = 0;
int len = strlen(str);
if(len != 18)
return 1;
else
{
const char *p = str;
while(*(p + 1) != '\0')
{
if(*p < '0' || *p > '9')
return 2;
p ++;
}
if(*p != 'X' && *p != 'x'&& (*p < '0' || *p > '9'))
return 3;
for(int i = 6; i < 10; i ++)
year = year * 10 + *(str+i) - '0';
if(year < 1900 || year > 2100)
return 4;
for(int i = 10; i < 12; i++)
month = month * 10 + *(str + i) - '0';
if(month < 10 && *(str + 10) != '0' || month > 12)
return 5;
for(int i = 12; i < 14; i ++)
day = day * 10 + *(str + i) - '0';
int months[2][13]= {0,31,28,31,30,31,30,31,31,30,31,30,31,0,31,29,31,30,31,30,31,31,30,31,30,31};
if((year%4 == 0&& year%100 != 0)||(year % 400 == 0))
{
if(day < 0 || day > months[1][month])
return 6;
}
else
if(day < 0 || day > months[0][month])
return 6;
}
return 0;
}
int main()
{
char ch[20];
while(cin>>ch)
{
int res = isValid(ch);
cout<<res<<endl;
}
}
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(请注意闰年的情况
#include <iostream>
#include <stdio.h>
#include <string>
using namespace std;
int isValid(const char *str)
{
int year = 0, month = 0, day = 0;
int len = strlen(str);
if(len != 18)
return 1;
else
{
const char *p = str;
while(*(p + 1) != '\0')
{
if(*p < '0' || *p > '9')
return 2;
p ++;
}
if(*p != 'X' && *p != 'x'&& (*p < '0' || *p > '9'))
return 3;
for(int i = 6; i < 10; i ++)
year = year * 10 + *(str+i) - '0';
if(year < 1900 || year > 2100)
return 4;
for(int i = 10; i < 12; i++)
month = month * 10 + *(str + i) - '0';
if(month < 10 && *(str + 10) != '0' || month > 12)
return 5;
for(int i = 12; i < 14; i ++)
day = day * 10 + *(str + i) - '0';
int months[2][13]= {0,31,28,31,30,31,30,31,31,30,31,30,31,0,31,29,31,30,31,30,31,31,30,31,30,31};
if((year%4 == 0&& year%100 != 0)||(year % 400 == 0))
{
if(day < 0 || day > months[1][month])
return 6;
}
else
if(day < 0 || day > months[0][month])
return 6;
}
return 0;
}
int main()
{
char ch[20];
while(cin>>ch)
{
int res = isValid(ch);
cout<<res<<endl;
}
}
- 公民的身份证号码检测
- 公民身份证号码的编排规则
- 18位公民身份证号码的编排规则
- 18位公民身份证号码的编排规则
- 我国公民的身份证号码合法性判断
- 公安部下属的全国公民身份证号码查询服务中心笔试题
- 18位公民身份证号码校验码的算法 18位身份证号码校验
- 身份证号码检测
- 关于公民身份证号码15位与18位互相转化的问题
- iOS开发 精确的身份证号码有效性检测
- 华为:身份证号码检测
- 身份证号码有效性检测
- 企业公民的内幕
- 麻木的IT公民
- 身份证号码图像提取--基于canny边缘检测的连通域检测算法
- 公民身份号码的校验
- JavaScript世界的一等公民
- JavaScript世界的一等公民
- 内存错误:CRT detected that the application wrote to memory after end of heap buffer
- v$sqlarea,v$sql,v$sqltext提供的sql语句区别
- dm3730和dm6437,dm6446,AM335x启动过程的不同
- 用java执行php文件并得到运行结果
- Lua脚本之语法基础快速入门
- 公民的身份证号码检测
- 【task】Android终止线程
- 空间RESUMABLE操作 (ora-01536、ora-06512)
- 0500
- Ogre粒子编辑器ParticleUniverse
- 数学专项number_theory:LA 4079
- 通过数据库存储过程调用Web服务的办法
- WINDOWS 逻辑坐标 设备坐标 屏幕坐标 客户区坐标
- ContentObserver +loader+CursorAdapter解释