题目描述:
给定一段"密文"字符串 s, 其中字符都是经过"密码本"映射的,现需要将"密文"解密并且输出映射的规则 ('a' - 'i')分别用('1' - '9')表示;('j' - 'z')分别用('10*' - '26*')表示约束:映射始终唯一
输入描述:
"密文"字符串
输出描述:
明文字符串
特别注意:
翻译后的文本的长度在 100 以内
示例1:
输入
20 * 19 * 20 *
输出
tst
C++源码:
cpp
#include <iostream>
#include <string>
int main() {
std::string s;
if (!(std::cin >> s)) {
return 0; // 如果输入失败,直接返回
}
std::string da = "";
for (int i = 0; i < s.length(); ++i) {
if (i + 2 < s.length() && s[i + 2] == '*') {
char code = static_cast<char>(((s[i] - '1') * 10 + (s[i + 1] - '1')) + 'l' - 1);
da += code;
i += 2; // 跳过已经处理过的字符
}
else {
char ch = static_cast<char>(s[i] - '1' + 'a');
da += ch;
}
}
std::cout << da << std::endl;
system("pause");
return 0;
}