JavaScript基础算法——凯撒密码Caesar cipher

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/funkstill/article/details/88097978

要求:

凯撒密码Caesar cipher,又叫移位密码。

移位密码也就是密码中的字母会按照指定的数量来做移位。

一个常见的案例就是ROT13密码,字母会移位13个位置。由'A' ↔ 'N', 'B' ↔ 'O',以此类推。

写一个ROT13函数,实现输入加密字符串,输出解密字符串。

所有的字母都是大写,不要转化任何非字母形式的字符(例如:空格,标点符号),遇到这些特殊字符,跳过它们。

样本:

rot13("SERR PBQR PNZC") 应该解码为 "FREE CODE CAMP"

rot13("SERR CVMMN!") 应该解码为 "FREE PIZZA!"

rot13("SERR YBIR?") 应该解码为 "FREE LOVE?"

rot13("GUR DHVPX OEBJA QBT WHZCRQ BIRE GUR YNML SBK.") 应该解码为 "THE QUICK BROWN DOG JUMPED OVER THE LAZY FOX."

解法:

function rot13(str) { 
  var newStr = "";
  for(var i=0;i<str.length;i++){
    if(str.charCodeAt(i)>=65&&str.charCodeAt(i)<=90){
      newStr+=String.fromCharCode((str.charCodeAt(i)+13-65)%26+65);
    }else{
      newStr+=String.fromCharCode(str.charCodeAt(i));
    }
  }
  return newStr;
}

rot13("HELLO");  // 你可以修改这一行来测试你的代码

猜你喜欢

转载自blog.csdn.net/funkstill/article/details/88097978