import java.util.Scanner;
/**
* 当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,
* 因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。
该校验的过程:
1、从卡号最后一位数字开始,逆向将奇数位(1、3、5等等)相加。
2、从卡号最后一位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,则将其减去9),再求和。
3、将奇数位总和加上偶数位总和,结果应该可以被10整除。
例如,卡号是:5432123456788881
则奇数、偶数位(用红色标出)分布:5432123456788881
奇数位和=35
偶数位乘以2(有些要减去9)的结果:1 6 2 6 1 5 7 7,求和=35。
最后35+35=70 可以被10整除,认定校验通过。
请编写一个程序,从键盘输入卡号,然后判断是否校验通过。通过显示:“成功”,否则显示“失败”。
比如,用户输入:356827027232780
程序输出:成功
* @author wangmeng
*
*/
public class 判断信用卡的正确性 {
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
String str = fanxiang(scan.next());
//System.out.println(str);
char[] c = str.toCharArray();
int a = jishuResult(c);
int b = oushuResult(c);
int d = a + b;
if(d%10==0)
System.out.println("成功");
else
System.out.println("失败");
}
//反向字符串
private static String fanxiang(String next) {
String s = "";
char[] c = next.toCharArray();
for(int i =0;i<c.length;i++){
s = c[i] + s;
}
return s;
}
//计算基数为的结果
private static int jishuResult(char[] c) {
int sum = 0;
for(int i=0;i<c.length;i+=2){
sum = sum + c[i] - '0';
}
return sum;
}
//计算偶数位的结果
private static int oushuResult(char[] c) {
int sum = 0;
for(int i = 1;i
=10)
a = a-9;
sum = sum + a;
}
return sum;
}
}
运行结果:
356827027232780
合法
当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。 该校验的过程:1、从卡号最后一位数字开始,逆
最新推荐文章于 2021-12-19 20:59:22 发布