位移密碼算法(JavaScript)

問題:

著名的凱撒密碼Caesar cipher,又叫移位密碼。html

移位密碼也就是密碼中的字母會按照指定的數量來作移位。函數

一個常見的案例就是ROT13密碼,字母會移位13個位置。由'A' ↔ 'N', 'B' ↔'O',以此類推。加密

寫一個ROT13函數,實現輸入加密字符串,輸出解密字符串。code

要求:

全部的字母都是大寫,不要轉化任何非字母形式的字符(例如:空格,標點符號),遇到這些特殊字符,就跳過它們。htm

解答:

function rot13(str) { // LBH QVQ VG!
    var start = "A".charCodeAt(0);
    var end = "Z".charCodeAt(0);
    var strList = str.split("");
    var judge, replace;
    for(var i = 0; i < str.length; i++){
        judge = strList[i].charCodeAt(0);
        if(judge <= end && judge >= start){
            replace = start + (judge - start + 13) % 26;
            strList[i] = String.fromCharCode(replace);
        }
    }
    newStr = strList.join("");
    return newStr;
}

// Change the inputs below to test
rot13("SERR PBQR PNZC");

連接:

https://www.w3cschool.cn/code...ip