車架號(VIN)校驗算法Java版

VIN碼國際通用,一共17位,包含數字0~9,和大部分英文字母(不包括I、O、Q)。第9位為校驗位,其值的計算方法:對其他位置求校驗和,然后除以11得到余數,如果余數為10則由X表示,這個余數就是第九位的值。

求校驗和的算法:每個位置的數字對應值和位置權重相乘,再累加。

VIN碼字符的數字對應值:

0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
A B C D E F G H J K L M N P R S T U V W X Y Z
1 2 3 4 5 6 7 8 1 2 3 4 5 7 9 2 3 4 5 6 7 8 9

VIN碼位置對應權重:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
8 7 6 5 4 3 2 10 0 9 8 7 6 5 4 3 2

Java版本判斷校驗和是否正確算法:

import java.util.HashMap;
import java.util.Map;

public class VinUtil {
    /**
     * 字符權重表
     */
    private static final Map<Character, Integer> CHAR_WEIGHTS = new HashMap<>();
    /**
     * 位置權重表
     */
    private static final int[] POS_WEIGHTS = new int[]{8, 7, 6, 5, 4, 3, 2, 10, 0, 9, 8, 7, 6, 5, 4, 3, 2};


    static {
        for (int i = 0; i < 10; i++) {
            CHAR_WEIGHTS.put(String.valueOf(i).charAt(0), i);
        }
        CHAR_WEIGHTS.put('A', 1);
        CHAR_WEIGHTS.put('B', 2);
        CHAR_WEIGHTS.put('C', 3);
        CHAR_WEIGHTS.put('D', 4);
        CHAR_WEIGHTS.put('E', 5);
        CHAR_WEIGHTS.put('F', 6);
        CHAR_WEIGHTS.put('G', 7);
        CHAR_WEIGHTS.put('H', 8);
        CHAR_WEIGHTS.put('J', 1);
        CHAR_WEIGHTS.put('K', 2);
        CHAR_WEIGHTS.put('L', 3);
        CHAR_WEIGHTS.put('M', 4);
        CHAR_WEIGHTS.put('N', 5);
        CHAR_WEIGHTS.put('P', 7);
        CHAR_WEIGHTS.put('R', 9);
        CHAR_WEIGHTS.put('S', 2);
        CHAR_WEIGHTS.put('T', 3);
        CHAR_WEIGHTS.put('U', 4);
        CHAR_WEIGHTS.put('V', 5);
        CHAR_WEIGHTS.put('W', 6);
        CHAR_WEIGHTS.put('X', 7);
        CHAR_WEIGHTS.put('Y', 8);
        CHAR_WEIGHTS.put('Z', 9);
    }


    public static boolean isValidVin(String vin) {
        if (null == vin) {
            return false;
        } else if (vin.trim().length() == 17) {
            vin = vin.toUpperCase();
            int sum = 0;
            int checkSum = 0;
            for (int i = 0; i < vin.length(); i++) {
                char code = vin.charAt(i);
                Integer cw = CHAR_WEIGHTS.get(code);
                if (cw == null) {
                    return false;
                }
                int pw = POS_WEIGHTS[i];
                sum += cw * pw;
                if (i == 8) {
                    // 獲取校驗位的值
                    if (code == 'X') {
                        checkSum = 10;
                    } else if (code >= '0' && code <= '9') {
                        checkSum = Integer.valueOf(String.valueOf(code));
                    } else {
                        return false;
                    }
                }
            }
            return checkSum == sum % 11;
        }
        return false;
    }
}
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 奇偶校驗、海明碼、CRC循環冗余校驗碼 三種校驗碼比較重要,需要牢記,在計算機網絡中用處較大 奇偶校驗 根據被傳輸...
    正經龍閱讀 9,420評論 0 1
  • 1)這本書為什么值得看: Python語言描述,如果學的Python用這本書學數據結構更合適 2016年出版,內容...
    孫懷闊閱讀 12,569評論 0 15
  • to do 分治法在每一層遞歸上都有三個步驟: 它的一般的算法設計模式如下: 其中|P|表示問題P的規模;n0為一...
    陳十十閱讀 278評論 0 0
  • 很多人總在想:“萬一我失敗怎么辦呢!” 可現實:“你有億萬身家嗎” 我:“沒有……” 現實:“你有千萬豪宅嗎” 我...
    jinma0606閱讀 166評論 0 0
  • 中午下班回家,習慣性地想摸出手機充電。可是摸遍包包口袋,手機不見了!我開始回憶下班前去了哪里,最后一次看手機在什么...
    LH來慧閱讀 663評論 5 32