2018-10-10 18:03:03 -04:00
|
|
|
---
|
|
|
|
id: 56533eb9ac21ba0edf2244e2
|
2020-12-16 00:37:30 -07:00
|
|
|
title: 凯撒密码
|
2018-10-10 18:03:03 -04:00
|
|
|
challengeType: 5
|
2020-09-07 16:17:22 +08:00
|
|
|
forumTopicId: 16003
|
2021-01-13 03:31:00 +01:00
|
|
|
dashedName: caesars-cipher
|
2018-10-10 18:03:03 -04:00
|
|
|
---
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
# --description--
|
2020-09-07 16:17:22 +08:00
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
<dfn>凯撒密码</dfn>是最简单且最广为人知的<dfn>密码</dfn>,也被称为<dfn>移位密码</dfn>。在移位密码中,明文中的字母通过按照一个固定数目进行偏移后被替换成新的字母。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
[ROT13](https://en.wikipedia.org/wiki/ROT13) 是一个被广泛使用的加密技术,明文中的所有字母都被移动 13 位。因此有:'A' ↔ 'N'、'B' ↔ 'O' 等等。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
请编写一个函数,用于解码一个被 [ROT13](https://en.wikipedia.org/wiki/ROT13) 编码的字符串,然后返回解码后的结果。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
所有解码后的字母都必须为字母大写。请不要解码非字母的字符(例如,空格、标点符号),但你需要在结果中保留它们。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
# --hints--
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
`rot13("SERR PBQR PNZC")` 应解码为 `FREE CODE CAMP`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
assert(rot13('SERR PBQR PNZC') === 'FREE CODE CAMP');
|
2018-10-10 18:03:03 -04:00
|
|
|
```
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
`rot13("SERR CVMMN!")` 应解码为 `FREE PIZZA!`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
```js
|
|
|
|
assert(rot13('SERR CVMMN!') === 'FREE PIZZA!');
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
`rot13("SERR YBIR?")` 应解码为 `FREE LOVE?`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
```js
|
|
|
|
assert(rot13('SERR YBIR?') === 'FREE LOVE?');
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
`rot13("GUR DHVPX OEBJA SBK WHZCF BIRE GUR YNML QBT.")` 应解码为 `THE QUICK BROWN FOX JUMPS OVER THE LAZY DOG.`。
|
2020-09-07 16:17:22 +08:00
|
|
|
|
2018-10-10 18:03:03 -04:00
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
assert(
|
|
|
|
rot13('GUR DHVPX OEBJA SBK WHZCF BIRE GUR YNML QBT.') ===
|
|
|
|
'THE QUICK BROWN FOX JUMPS OVER THE LAZY DOG.'
|
|
|
|
);
|
2018-10-10 18:03:03 -04:00
|
|
|
```
|
2020-08-13 17:24:35 +02:00
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
# --seed--
|
|
|
|
|
|
|
|
## --seed-contents--
|
|
|
|
|
|
|
|
```js
|
|
|
|
function rot13(str) {
|
|
|
|
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
|
|
|
|
rot13("SERR PBQR PNZC");
|
|
|
|
```
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
# --solutions--
|
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
```js
|
|
|
|
var lookup = {
|
|
|
|
'A': 'N','B': 'O','C': 'P','D': 'Q',
|
|
|
|
'E': 'R','F': 'S','G': 'T','H': 'U',
|
|
|
|
'I': 'V','J': 'W','K': 'X','L': 'Y',
|
|
|
|
'M': 'Z','N': 'A','O': 'B','P': 'C',
|
|
|
|
'Q': 'D','R': 'E','S': 'F','T': 'G',
|
|
|
|
'U': 'H','V': 'I','W': 'J','X': 'K',
|
|
|
|
'Y': 'L','Z': 'M'
|
|
|
|
};
|
|
|
|
|
|
|
|
function rot13(encodedStr) {
|
|
|
|
var codeArr = encodedStr.split(""); // String to Array
|
|
|
|
var decodedArr = []; // Your Result goes here
|
|
|
|
// Only change code below this line
|
|
|
|
|
|
|
|
decodedArr = codeArr.map(function(letter) {
|
|
|
|
if(lookup.hasOwnProperty(letter)) {
|
|
|
|
letter = lookup[letter];
|
|
|
|
}
|
|
|
|
return letter;
|
|
|
|
});
|
|
|
|
|
|
|
|
// Only change code above this line
|
|
|
|
return decodedArr.join(""); // Array to String
|
|
|
|
}
|
|
|
|
```
|