赞
踩
给定一段"密文"字符串 s, 其中字符都是经过"密码本"映射的,现需要将"密文"解密并且输出映射的规则 ('a' - 'i')分别用('1' - '9')表示;('j' - 'z')分别用('10*' - '26*')表示约束:映射始终唯一
“密文”字符串
明文字符串
特别注意:
翻译后的文本的长度在 100 以内
输入
20 * 19 * 20 *
输出
tst
C++源码:
- #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;
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。