zoukankan      html  css  js  c++  java
  • java检验银行卡号

    1. /* 
    2.     校验过程:  
    3.     1、从卡号最后一位数字开始,逆向将奇数位(1、3、5等等)相加。  
    4.     2、从卡号最后一位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,将个位十位数字相加,即将其减去9),再求和。  
    5.     3、将奇数位总和加上偶数位总和,结果应该可以被10整除。        
    6.     */     
    7.         /**  
    8.         * 校验银行卡卡号  
    9.         */    
    10.        public static boolean checkBankCard(String bankCard) {    
    11.                 if(bankCard.length() < 15 || bankCard.length() > 19) {  
    12.                     return false;  
    13.                 }  
    14.                 char bit = getBankCardCheckCode(bankCard.substring(0, bankCard.length() - 1));    
    15.                 if(bit == 'N'){    
    16.                     return false;    
    17.                 }    
    18.                 return bankCard.charAt(bankCard.length() - 1) == bit;    
    19.        }    
    20.   
    21.        /**  
    22.         * 从不含校验位的银行卡卡号采用 Luhm 校验算法获得校验位  
    23.         * @param nonCheckCodeBankCard  
    24.         * @return  
    25.         */    
    26.        public static char getBankCardCheckCode(String nonCheckCodeBankCard){    
    27.            if(nonCheckCodeBankCard == null || nonCheckCodeBankCard.trim().length() == 0    
    28.                    || !nonCheckCodeBankCard.matches("\d+")) {    
    29.                //如果传的不是数据返回N    
    30.                return 'N';    
    31.            }    
    32.            char[] chs = nonCheckCodeBankCard.trim().toCharArray();    
    33.            int luhmSum = 0;    
    34.            for(int i = chs.length - 1, j = 0; i >= 0; i--, j++) {    
    35.                int k = chs[i] - '0';    
    36.                if(j % 2 == 0) {    
    37.                    k *= 2;    
    38.                    k = k / 10 + k % 10;    
    39.                }    
    40.                luhmSum += k;               
    41.            }    
    42.            return (luhmSum % 10 == 0) ? '0' : (char)((10 - luhmSum % 10) + '0');    
    43.        }   
  • 相关阅读:
    Java在ACM中的应用
    acm->stl
    残缺棋盘--状压DP
    EOJ Monthly 2019.3 A
    【CF1141E】Superhero Battle
    AtCoder Grant Contest 10.F 博弈
    莫比乌斯反演总结
    P2257 YY的GCD
    BZOJ1011 莫比乌斯反演(基础题
    HDU1695 莫比乌斯反演
  • 原文地址:https://www.cnblogs.com/kim-liu/p/7773236.html
Copyright © 2011-2022 走看看