gpt4 book ai didi

java - 使用 Luhn 算法检查信用卡

转载 作者:行者123 更新时间:2023-12-02 10:44:43 24 4
gpt4 key购买 nike

我正在尝试用 JAVA 制作一个应用程序来检查用户输入的信用卡号是否有效。

以下是模数 10 检查的步骤:

第一步:从右到左每隔两个数字加倍。如果数字加倍得到两位数,则将这两位数相加得到一位数。

第 2 步:现在添加第 1 步中的所有个位数

第三步:将卡号从右到左奇数位的所有数字相加

第4步:将第2步和第3步的结果相加

第五步:如果第四步的结果能被10整除,则卡号有效;否则无效。在这种情况下,卡号无效 - 因为 75 不能被 10 整除。

到目前为止,我的问题是,我尝试的每个卡号(使用有效号码)都被告知它无效。我尝试使用调试工具,看起来我的 sum 值总是错误的。我需要帮助找出我在计算中搞砸的地方或者我是否遗漏了一些东西。

public class CreditCardChecker {

/**
* @param args the command line arguments
*/
public static void main(String[] args) {
// TODO code application logic here
Scanner sc = new Scanner(System.in);

System.out.println("Enter credit card number to check validity: ");
System.out.println();
String cardNo = sc.next();
int sum = FindSum(cardNo);

if ((sum % 10) == 0) {
System.out.println("The card number is VALID.");
} else {
System.out.println("The card number is INVALID");
}

}

public static int FindSum(String cardNo) {

//CONVERTING CARD NUMBER INTO AN ARRAY
int[] digits = new int[cardNo.length()];
for (int i = 0; i < cardNo.length(); i++) {
digits[i] = Character.getNumericValue(cardNo.charAt(i));
}

//DOUBLE EVERY OTHER NUMBER FROM RIGHT TO LEFT
for (int i = digits.length - 1; i >= 0; i -= 2) {

digits[i] += digits[i];

if (digits[i] > 9) {
digits[i] = digits[i] - 9;
}
}
int sum = 0;
for (int i = 0; i < digits.length; i++) {
sum += digits[i];
}

sum *= 9;
return sum;

}

}

最佳答案

您在执行该步骤时出错:

Step1: double every second digit from right to left. If doubling of a digit results in a two-digit number, add up the two digits to get a single-digit number.

您从信用卡号的最后(第 n)位数字开始迭代,而应该从第(n-1)位数字开始。即改变:

for (int i = digits.length - 1; i >= 0; i -= 2)

for (int i = digits.length - 2; i >= 0; i -= 2)

此外,请记住,您的 FindSum(String cardNo) 方法仅适用于其中不带任何空格的 String(这就是您获取输入的方式) )。

关于java - 使用 Luhn 算法检查信用卡,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52671553/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com