zoukankan      html  css  js  c++  java
  • 算法笔记_101:蓝桥杯练习 算法提高 身份证号码升级(Java)

    目录

    1 问题描述

    2 解决方案

     


    1 问题描述

    问题描述
      从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位字符串是否合理

     


    2 解决方案

    具体代码如下:

    import java.util.Scanner;
    
    public class Main {
        
        public void printResult(String A) {
            char[] arrayA = A.toCharArray();
            int[] result = new int[18];
            for(int i = 0;i < A.length();i++) {
                if(i >= 6)
                    result[i + 2] = arrayA[i] - '0';
                else {
                    result[i] = arrayA[i] - '0';
                }
            }
            result[6] = 1;
            result[7] = 9;
            int[] temp = {7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
            char[] temp1 = {'1','0','x','9','8','7','6','5','4','3','2'};
            int sum = 0;
            for(int i = 0;i < 17;i++) 
                sum += result[i] * temp[i];
            sum %= 11;
            for(int i = 0;i < 17;i++)
                System.out.print(result[i]);
            System.out.print(temp1[sum]);
        }
        
        public static void main(String[] args) {
            Main test = new Main();
            Scanner in = new Scanner(System.in);
            String A = in.nextLine();
            test.printResult(A);
        }
    }
  • 相关阅读:
    java 可变參数列表
    Java -Xms -Xmx -Xss -XX:MaxNewSize -XX:MaxPermSize含义记录
    hdu 4939
    什么是堆和栈,它们在哪儿?
    PPAPI插件与浏览器的通信
    Java&amp;Xml教程(十一)JAXB实现XML与Java对象转换
    Heavy Transportation
    Python学习笔记-小记
    C/C++知识要点5——智能指针原理及自己定义实现
    小米2S电池电量用尽充电无法开机解决方法
  • 原文地址:https://www.cnblogs.com/liuzhen1995/p/6582254.html
Copyright © 2011-2022 走看看