下面我们来介绍风靡全球的凯撒密码Caesar cipher ,又叫移位密码。
移位密码也就是密码中的字母会按照指定的数量来做移位。
一个常见的案例就是ROT13密码,字母会移位13个位置。由'A'
↔ 'N', 'B' ↔ 'O',以此类推。
写一个ROT13函数,实现输入加密字符串,输出解密字符串。
所有的字母都是大写,不要转化任何非字母形式的字符(例如:空格,标点符号),遇到这些特殊字符,跳过它们。
- function rot13(str) { // LBH QVQ VG!
- var str1 = [];
- for (var i = 0; i < str.length; i++ ) {
- var num = str[i].charCodeAt(); //获得字符串中某个具体字符的 Unicode 编码。
- if (num >= 65 && num <= 77)
- num = num + 13;
- else if (num > 77 && num < 91)
- num = num - 13;
- str1.push(String.fromCharCode(num)); //可接受一个指定的 Unicode 值,然后返回一个字符串
- }
- return str1.join("");
- }
-
- // Change the inputs below to test
- rot13("GUR DHVPX OEBJA QBT WHZCRQ BIRE GUR YNML SBK.");
rot13("SERR PBQR PNZC") 应该解码为 "FREE CODE CAMP"
|