Java高职蓝桥杯校内选拔题身份证的奥秘
来源:互联网 发布:中国光伏行业协会数据 编辑:程序博客网 时间:2024/05/18 15:06
背景
18位身份证标准在国家质量技术监督局于1999年7月1日实施的GB11643-1999《公民身份号码》中做了明确的规定。 GB11643-1999《公民身份号码》为GB11643-1989《社会保障号码》的修订版,其中指出将原标准名称"社会保障号码"更名为"公民身份号码",另外GB11643-1999《公民身份号码》从实施之日起代替GB11643-1989。GB11643-1999《公民身份号码》主要内容如下:
一、范围
该标准规定了公民身份号码的编码对象、号码的结构和表现形式,使每个编码对象获得一个唯一的、不变的法定号码。
二、编码对象
公民身份号码的编码对象是具有中华人民共和国国籍的公民。
三、号码的结构和表示形式
1、号码的结构
公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
2、地址码
表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。
3、出生日期码
表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。
4、顺序码
表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。
5、校验码
(1)十七位数字本体码加权求和公式
S = Sum(Ai * Wi), i = 0, ... , 16 ,先对前17位数字的权求和
Ai: 表示第i位置上的身份证号码数字值
Wi: 表示第i位置上的加权因子
Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2
(2)计算模
Y = mod(S, 11)
(3)通过模得到对应的校验码
Y: 0 1 2 3 4 5 6 7 8 9 10
校验码: 1 0 X 9 8 7 65 4 3 2
四、举例如下:
北京市朝阳区: 11010519491231002X
广东省汕头市:440524188001010014
15位的身份证号升级办法:
15位的身份证号:dddddd yymmddxx p
18位的身份证号:dddddd yyyymmddxx p y
其中dddddd为地址码(省地县三级)
yyyymmdd yymmdd 为出生年月日
xx顺号类编码
p性别
15 位的 yy 年升为 18 位后,变成 19yy年,但对于百岁以上老人, 则为 18yy 年,此时,他们的最后三位顺序码为996, 997, 998 或 999 来标记。
输入
输入n组身份证号码,第一行为个数,以后每行为身份证号码。
输出
如果输入的身份证号码为15位,则将其升级为18位后显示输出;否则判断其是否为合法身份证号,并逐行输出。
例:
输入:
4
350622197904130331
11010519491231002X
110105491231002
110105491231996
输出:
Invalid
Valid
11010519491231002X
110105184912319965
源代码
import java.util.Scanner;
public class test_eleven {
public static void main(String[] args) {
String content[];
int[] Wi_18 = {7, 9, 10 ,5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
int[] Mo = {1,0,-1,9, 8, 7, 6, 5, 4, 3, 2};
Scanner scanner = new Scanner(System.in);
int digital = scanner.nextInt();
content = new String[digital];
for(int i = 0;i<digital;i++){
content[i] = scanner.next();
}
for(int i =0;i<content.length;i++){
if(content[i].length()==15){
char[] sj = new char[15];
char[] sj2 = new char[18];
int mo=0;
for(int a =0;a<15;a++){
sj[a]=content[i].charAt(a);
}
if(sj[12]=='9'&&sj[13]=='9'&&(sj[14]=='6'||sj[14]=='7'||sj[14]=='8'||sj[14]=='9')){
sj2[6] = '1';
sj2[7] = '8';
}else{
sj2[6] = '1';
sj2[7] = '9';
}
for(int b=0;b<6;b++){
sj2[b] = sj[b];
}
for(int c=6;c<15;c++){
sj2[c+2] = sj[c];
}
for(int d=0;d<17;d++){
mo += (sj2[d]-'0')*Wi_18[d];
}
mo %=11;
mo = Mo[mo];
if(mo==-1){
sj2[17] = 'X';
}else{
sj2[17] = (char)(mo+'0');
}
for(int e =0;e<18;e++){
System.out.print(sj2[e]);
}
System.out.println();
}else{
char[] sj = new char[18];
int mo=0;
for(int a=0;a<18;a++){
sj[a] = content[i].charAt(a);
}
for(int b=0;b<17;b++){
mo += (sj[b]-'0')*Wi_18[b];
}
mo %=11;
mo = Mo[mo];
if(mo==-1){
if(sj[17]=='X')
System.out.println("Valid");
else
System.out.println("Invalid");
}else{
if((sj[17]-'0')==mo)
System.out.println("Valid");
else
System.out.println("Invalid");
}
}
}
}
}
- Java高职蓝桥杯校内选拔题身份证的奥秘
- Java高职蓝桥杯校内选拔题
- Java高职蓝桥杯校内选拔题
- Java高职蓝桥杯校内选拔题
- Java高职蓝桥杯校内选拔题素数问题
- Java高职蓝桥杯校内选拔题求最大数约数
- Java高职蓝桥杯校内选拔题计算蔬菜总价
- Java高职蓝桥杯校内选拔题该存多少钱
- Java高职蓝桥杯校内选拔题水仙花数
- Java高职蓝桥杯校内选拔题回文字符串
- Java高职蓝桥杯校内选拔题前N项之和
- 第五届“蓝桥杯”全国软件 校内选拔赛试题(Java组)11、(18分) 身份证的奥秘
- 蓝桥杯校内选拔第一题
- 蓝桥杯校内选拔第二题
- 蓝桥杯校内选拔第三题
- 蓝桥杯校内选拔第四题
- 蓝桥杯校内选拔第五题
- 蓝桥杯校内选拔第六题
- ECSide标签属性说明之<ec:column>
- java 匿名内部类使用
- Android从零开搞系列:自定义View(7)ScrollTo+ScrollBy+Scroller+NestedScrolling机制(下)
- Java高职蓝桥杯校内选拔题前N项之和
- SQL Server 常用命令总结
- Java高职蓝桥杯校内选拔题身份证的奥秘
- 图片
- 此证书仍然无效
- 链表操作笔记
- BP 算法之一种直观的解释
- C#开发微信公众平台(附Demo)
- 图的建立、广度优先遍历和深度优先遍历
- Android中ImageView的scaleType属性详解
- Linux下Tomcat的启动、关闭、杀死进程