您的位置:首页 > 其它

蓝桥杯_算法提高_身份证升级(简单字符处理)

2016-04-01 19:26 225 查看
问题描述

  从1999年10月1日开始,公民身份证号码由15位数字增至18位。(18位身份证号码简介)。升级方法为:

  1、把15位身份证号码中的年份由2位(7,8位)改为四位。

  2、最后添加一位验证码。验证码的计算方案:

  将前 17 位分别乘以对应系数 (7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2) 并相加,然后除以 11 取余数,0-10 分别对应 1 0 x 9 8 7 6 5 4 3 2。

  请编写一个程序,用户输入15位身份证号码,程序生成18位身份证号码。假设所有要升级的身份证的四位年份都是19××年

输入格式

  一个15位的数字串,作为身份证号码

输出格式

  一个18位的字符串,作为升级后的身份证号码

样例输入

110105491231002

样例输出

11010519491231002x

数据规模和约定

  不用判断输入的15位字符串是否合理

import java.util.Scanner;

/**
* @author 翔
*
*/
public class Main {
private static int[] arr={7 ,9 ,10 ,5 ,8 ,4 ,2 ,1 ,6 ,3 ,7 ,9 ,10 ,5 ,8 ,4 ,2};
private static char[] p={'1' ,'0' ,'x' ,'9' ,'8' ,'7' ,'6' ,'5' ,'4' ,'3' ,'2'};

/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
String s=sc.next();
s=s.substring(0,6)+"19"+s.substring(6);
char[] charArr=s.toCharArray();
int[] numArr=new int[17];
for(int i=0;i<17;i++){
numArr[i]=charArr[i]-'0';
}
int sum=0;
for(int i=0;i<17;i++){
sum+=(numArr[i]*arr[i]);
}
int remain=sum%11;
s+=p[remain];
System.out.println(s);
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: