华为机考真题 -- 密码解密

题目描述:

给定一段"密文"字符串 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;
}
相关推荐
8Qi84 分钟前
LeetCode 208:实现 Trie(前缀树)—— Java 题解 ✅
java·算法·leetcode·二叉树·tire树
吴可可1236 分钟前
CAD2004二次开发C#可行性解析
算法
字节高级特工9 分钟前
C++11(二) 革新:引用折叠与lambda表达式
java·开发语言·c++·算法
碎碎念_49212 分钟前
”二分“高频题型总结:最小最大值、最大最小值、满足条件最小 / 最大
算法·二分
无限码力16 分钟前
华为非AI方向笔试真题 - 任意矩形图案解锁路径验证
华为·华为非ai方向笔试真题·华为笔试真题·华为最新笔试真题
co_wait16 分钟前
【华为】OSPF协议Stub和NSSA区域
华为
罗超驿23 分钟前
14.LeetCode 438 题解:滑动窗口+哈希表找所有字母异位词
java·算法·leetcode
白驹笙鸣24 分钟前
STL allocator作用
开发语言·c++
小小编程路25 分钟前
C++ STL 原理与性能
开发语言·c++
小欣加油33 分钟前
leetcode239 滑动窗口最大值
数据结构·c++·算法·leetcode·哈希算法