当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。
该校验的过程:
1、从卡号最后一位数字开始,逆向将奇数位(1、3、5等等)相加。
2、从卡号最后一位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,则将其减去9),再求和。
3、将奇数位总和加上偶数位总和,结果应该可以被10整除。
例如,卡号是:5432123456788881
则,奇数位和=35
偶数位乘以2(有些要减去9)的结果:1 6 2 6 1 5 7 7,求和=35。
最后35+35=70 可以被10整除,认定校验通过。
请编写一个程序,从键盘输入卡号,然后判断是否校验通过。通过显示:“成功”,否则显示“失败”。
比如,用户输入:356827027232780
程序输出:成功
分析:模拟
import java.util.Scanner;
public class Main {
public static boolean isOk(int[] a,int n)
{
int sum1=0,sum2=0;
int temp=0;
for(int i=1;i<=n;i+=2)
{
sum1+=a[i];
}
for(int i=2;i<=n;i+=2)
{
temp=a[i]*2;
if((temp+"").length()==2)
{
temp=temp-9;
}
sum2+=temp;
}
if((sum1+sum2)%10!=0)
{
return false;
}
return true;
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int[] a = new int[100];
String s =in.next();
int n = s.length();
int j=1;
for(int i=n-1;i>=0;i--)
{
a[j] = s.charAt(i)-'0';
j++;
}
if(isOk(a,n))
{
System.out.println("成功");
}else {
System.out.println("失败");
}
}
}