当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。
该校验的过程:
1、从卡号最后一位数字开始,逆向将奇数位(1、3、5等等)相加。
2、从卡号最后一位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,则将其减去9),再求和。
3、将奇数位总和加上偶数位总和,结果应该可以被10整除。
例如,卡号是:5432123456788881
逆向奇数位为 4 2 2 4 6 8 8 1 和 = 35
逆向偶数位乘以2(有些要减去9)的结果:1 6 2 6 1 5 7 7,求和 = 35。
最后 35 + 35 = 70 可以被10整除,认定校验通过。
请编写一个程序,从标准输入获得卡号,然后判断是否校验通过。
通过显示:“成功”,否则显示“失败”。
比如,
输入:356827027232780
【Java基础|信用卡校验】程序输出:成功
import java.util.Scanner;
public class TestArray {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
//输入需要校验的信用卡号
String number = sc.nextLine();
int oddNumber = OddNumber(number);
int evenNumber = EvenNumber(number);
if ((oddNumber + evenNumber) % 10 == 0)
System.out.println("成功");
else
System.out.println("失败");
} //计算奇数
public static int OddNumber(String number) {
int total = 0;
for (int i = number.length() - 1;
i >= 0;
i = i - 2) {
total += number.charAt(i) - '0';
}
return total;
} //计算偶数
public static int EvenNumber(String number) {
int total = 0;
for (int i = number.length() - 2;
i >= 0;
i = i - 2) {
//如果大于两位数
if ((number.charAt(i) - '0') * 2 >= 10) {
//则减去9
total += (number.charAt(i) - '0') * 2 - 9;
} else {
total += (number.charAt(i) - '0') * 2;
}
}
return total;
}
}
推荐阅读
- python蓝桥杯|python蓝桥杯基础练习 十六进制转八进制
- 刷题记录|【蓝桥必胜】试题 算法训练 kAc给糖果你吃-贪心排序
- Python|蓝桥杯 平面切割 Python
- Python|Python 每日一练 二分查找 搜索旋转排序数组 详解
- 遇见蓝桥遇见你|小唐开始刷蓝桥(一)2020年第十一届C/C++ B组第二场蓝桥杯省赛真题
- 遇见蓝桥遇见你|小唐开始刷蓝桥(三)2018年第九届C/C++ B组蓝桥杯省赛真题
- Integer常量池结合源码解析
- Java基础|Java 打印空心等腰三角形(方法2)
- gradle 每次运行都会下载依赖的解决办法
- 使用vector代替数组