凱撒密碼 Caesars Cipher

凱撒密碼
(讓上帝的歸上帝,凱撒的歸凱撒)
下面我們來(lái)介紹風(fēng)靡全球的凱撒密碼Caesar cipher,又叫移位密碼。
移位密碼也就是密碼中的字母會(huì)按照指定的數(shù)量來(lái)做移位。
一個(gè)常見(jiàn)的案例就是ROT13密碼,字母會(huì)移位13個(gè)位置。由'A' ? 'N', 'B' ? 'O',以此類推。
寫(xiě)一個(gè)ROT13函數(shù),實(shí)現(xiàn)輸入加密字符串,輸出解密字符串。
所有的字母都是大寫(xiě),不要轉(zhuǎn)化任何非字母形式的字符(例如:空格,標(biāo)點(diǎn)符號(hào)),遇到這些特殊字符,跳過(guò)它們。
當(dāng)你完成不了挑戰(zhàn)的時(shí)候,記得開(kāi)大招'Read-Search-Ask'。

function rot13(str) { // LBH QVQ VG!
  // 請(qǐng)把你的代碼寫(xiě)在這里
  return str;
}
rot13("SERR PBQR PNZC");  // 你可以修改這一行來(lái)測(cè)試你的代碼

提示可用的語(yǔ)句:

String.charCodeAt()
String.fromCharCode()

步驟分析:

  1. 此處需要通過(guò)獲取字符的UTF-18(即ACSII碼),大寫(xiě)字母的UTF-18碼區(qū)間在65-90之間,不在此區(qū)間的可以不進(jìn)行運(yùn)算
  2. 大于中間值(77)的可以-13并輸出相應(yīng)字符追加到新字符串當(dāng)中
  3. 小于或等于中間值(77)的可以+13并輸出相應(yīng)字符追加到新字符串中
  4. 合并字符串并輸出
  5. 需要注意的點(diǎn):
    • .charCodeAt()方法的一般格式是:字符串.chartCodeAr(字符串索引)
    • .fromCharCode()方法一般格式是:字符類型.fromCharCode(UTF-18編碼)
function rot13(str) {
  var tem=[];
  for(var i=0; i<str.length; i++){      //通過(guò)循環(huán)檢索字符串每個(gè)字符
    var ix=str.charCodeAt(i);
    if (ix<65 || ix>90){                //首先把UTF-18不在65-90區(qū)間的原樣輸出
      tem.push(String.fromCharCode(ix));
    }else if(ix>77){                    //大于UTF-18中間值的-13并輸出相應(yīng)字符
      tem.push(String.fromCharCode(ix-13));
    }else{                          //否則+13并輸出相應(yīng)字符
      tem.push(String.fromCharCode(ix+13));
    }
  }
  return tem.join("");
}
rot13("SERR PBQR PNZC");
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 整理 代碼/整理 術(shù)語(yǔ)整理 代碼/整理 CSS:層疊樣式表 CSS中的元素樣式設(shè)置叫做類選擇器:.be-text{...
    Jadon7閱讀 704評(píng)論 0 1
  • 凱撒密碼 Caesars Cipher 凱撒密碼 (讓上帝的歸上帝,凱撒的歸凱撒) 下面我們來(lái)介紹風(fēng)靡全球的凱撒密...
    Jadon7閱讀 1,071評(píng)論 0 3
  • 凱撒密碼 (讓上帝的歸上帝,凱撒的歸凱撒) 下面我們來(lái)介紹風(fēng)靡全球的凱撒密碼Caesar cipher,又叫移位密...
    yyggfffg閱讀 998評(píng)論 0 0
  • 終于把FCC的基礎(chǔ)javascript算法做完了,來(lái)總結(jié)一下。 翻轉(zhuǎn)字符串 先把字符串轉(zhuǎn)化成數(shù)組,再借助數(shù)組的re...
    少年vv閱讀 902評(píng)論 5 3
  • 1、翻轉(zhuǎn)字符串(Reverse a String) 翻轉(zhuǎn)字符串先把字符串轉(zhuǎn)化成數(shù)組,再借助數(shù)組的reverse方法...
    Iris_mao閱讀 723評(píng)論 1 3

友情鏈接更多精彩內(nèi)容