NowCode:HJ29 字符串加解密

题目: 字符串加解密

规定这样一种密码的加密方法:
∙ ∙对于密码中的英文字母,按照字母表顺序,向后移动一位,同时改变大小写,即 ZZ 转换为 aa ,AA 转换为 bb ,BB 转换为 cc ,⋯⋯ ,YY 转换为 zz ,ZZ 转换为 aa 。
∙ ∙对于密码中的数字,增加 11 ,99 转换为 00 。
字符串的解密方法即为加密方法的逆过程。

现在,对于给定的明文字符串 ss ,将其加密;对于给定的密文字符串 tt ,将其解密。

输入描述:

第一行输入一个长度为 1≦length(s)≦1031≦length(s)≦103 的字符串 ss ,代表给定的明文字符串;
第二行输入一个长度为 1≦length(t)≦1031≦length(t)≦103 的字符串 tt ,代表给定的密文字符串。

除此之外,保证字符串 ss 和 tt 中仅包含英文字母和数字。

输出描述:

第一行输出一个字符串,代表加密后的 ss
第二行输出一个字符串,代表解密后的 tt

示例1

1
2
3
4
5
6
7
输入:
abcdefg1
0BCDEFGH

输出:
BCDEFGH2
9abcdefg

题解

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include <cstddef>
#include <iostream>
#include <string>
using namespace std;

void TransStr(std::string& input) {
for (size_t i = 0; i < input.size(); i++) {
if (input[i] >= 'A' && input[i] <= 'Z') {
if (input[i] == 'Z') {
input[i] = 'a';
} else {
input[i] += 33;
}
} else if (input[i] >= 'a' && input[i] <= 'z') {
if (input[i] == 'z') {
input[i] = 'A';
} else {
input[i] -= 31;
}
} else if (input[i] >= '0' && input[i] <= '9') {
if (input[i] == '9') {
input[i] = '0';
} else {
input[i] += 1;
}
} else {
continue;
}
}
}

void FromStr(std::string& outPut) {
for (size_t i = 0; i < outPut.size(); i++) {
if (outPut[i] >= 'A' && outPut[i] <= 'Z') {
if (outPut[i] == 'A') {
outPut[i] = 'z';
} else {
outPut[i] += 31;
}
} else if (outPut[i] >= 'a' && outPut[i] <= 'z') {
if (outPut[i] == 'a') {
outPut[i] = 'Z';
} else {
outPut[i] -= 33;
}
} else if (outPut[i] >= '0' && outPut[i] <= '9') {
if (outPut[i] == '0') {
outPut[i] = '9';
} else {
outPut[i] -= 1;
}
} else {
continue;
}
}
}

int main() {
std::string firStr;
std::string secStr;
getline(cin, firStr);
getline(cin, secStr);
TransStr(firStr);
FromStr(secStr);
cout << firStr << endl;
cout << secStr << endl;
}

思路

加密 和 解密

解密方法为加密方法的逆过程