1. 程式人生 > >java模擬題第十一題---------判斷信用卡的正確性

java模擬題第十一題---------判斷信用卡的正確性

[size=medium]當你輸入信用卡號碼的時候,有沒有擔心輸錯了而造成損失呢?其實可以不必這麼擔心,因為並不是一個隨便的信用卡號碼都是合法的,它必須通過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
程式輸出:成功
[/size]

/**
* @category Luhn演算法 判斷信用卡號是否正確
* @author liucanwen
* @2012年2月18日 21:11:21
*/
public class Luhn
{
public static void main(String[] args)
{
System.out.print("請輸入信用卡號:");
Scanner scanner = new Scanner(System.in);

String result = Luhn.getResult(scanner.nextLine());
System.out.println(result);
}

public static String getResult(String cardNumber)
{
//將輸入的信用卡號轉換成char[]
char[] chars = cardNumber.toCharArray();
//判斷輸入的信用卡號是否正確
if(chars == null || chars.length < 1)
return "你輸入的卡號不正確!";

int countOddNum = 0;//逆向奇數位數字總和
int countEvenNum = 0;//逆向偶數位數字總和

//通過迴圈,得到逆向奇數位數字總和
for(int i = chars.length; i > 0; i=i-2)
{
countOddNum += (chars[i-1] - '0');//得到該逆向奇數位數字並進行累加

int perEvenNum = 2 * (chars[i - 2] - '0');//得到該逆向偶數位數字
if(perEvenNum > 9)//判斷該偶數位數字是否大於9
perEvenNum -= 9;
countEvenNum += perEvenNum;//將逆向偶數位數字進行累加
}
//判斷奇數和偶數位數字總和是否可以被10整除
if((countOddNum + countEvenNum) % 10 == 0)
return "成功";
return "失敗";
}
}