信用卡号校验

信用卡号校验

当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,

因为并不是一个随便的信用卡号码都是合法的,它必须通过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

程序输出:成功

package marslin;

import java.util.Scanner;

public class 信用卡号校验23 {

	public static void main(String[] args) {
		boolean isS;
		Scanner s = new Scanner(System.in);
		String str = s.nextLine();
		isS = doJob(str);
		if (isS == true) {
			System.out.print("成功");
		} else {
			System.out.print("失败");
		}

	}

	private static boolean doJob(String str) {
		StringBuffer sb = new StringBuffer();
		for (int i = str.length() - 1; i >= 0; i--) {
			char get = str.charAt(i);
			sb.append(get);
		}
		String s = sb.toString();
		int jsum = 0, osum = 0;
		for (int i = 0; i < s.length(); i++) {
			int get = s.charAt(i) - '0';
			if ((i + 1) % 2 == 0) {
				get = 2 * get;
				if (get >= 10) {
					get = get - 9;
				}
				osum += get;
			} else {
				jsum += get;
			}
		}
		if ((osum + jsum) % 10 == 0) {
			return true;
		} else
			return false;
	}
}


你可能感兴趣的:(数据结构,算法,蓝桥杯)