缺一位身份证号码时识别计算

在女友忘记身份证号码的情况下,通过12306仅显示的15位号码,了解到身份证最后一位是校验位。文章介绍了根据身份证号码的校验规则,如何在缺失最后一位的情况下推算出可能的正确号码。详细步骤包括将17位数字乘以特定系数相加,然后除以11得到余数,再根据余数确定校验位。代码实现时需要注意防止数组越界异常,并提供了一个允许输入一个未知字符"*"的主方法来测试不同情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有一次女朋友身份证找不到了,但是那时候急需要查看身份证号码,最绝的是20岁的巨婴连身份证号码都记不住,突然想到之前给他买过火车票,当我激动的打开12306才发现身份证后面只显示了三位,也就是说还差一位,我们都知道最后一位是校验位,也就是说缺一位是可以推出来的。哈哈哈哈哈,突然伟岸好多,今天我们来看看如何验证一个18位的身份证是否正确。
首先我们通过百度百科查的如下规则

  1. 将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 ;
  2. 将这17位数字和系数相乘的结果相加;
  3. 用加出来和除以11,看余数是多少;
  4. 余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字。其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2;

如果我们获得一个18位的字符串,先转换位数组

String s[]= sc.split("");

1.我们知道身份证存在x,所以我们需要将他转化为10

        List<Integer> number= new ArrayList<>();
       try {
               for (String str : s) {
                        if (str.equals("x") || str.equals("X")) {
                            str = "10";
                        }
               number.add(Integer.valueOf(str));
               }
       }catch (Exception e){
               System.out.println("身份证号码不能有除x和数字以外的其他字符");
            }

2.接下来就是前17位和系数相乘相加

public static final List<Integer> NUMBER =
            Arrays.asList(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);
int sum = 0;
for(int i=0;i<17;i++){
     sum = sum+ number.get(i)*NUMBER.get(i);
  }
        sum = sum % 11;

3.接下来我们发现余数为0和1时,对应数为1和0(之和为1),其他的余数和对应数之和为12

     if (sum==0 || sum =
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值