华为od机试真题:密码解密(Python)
题目描述
给定一段 “密文”字符串 s
,其中字符都是经过 “密码本” 映射的,现需要将“密文”解密并且输出。
映射的规则:
- (
a
−i
) 分别用(1
−9
)表示; - (
j
−z
) 分别用(10∗
−26∗
)表示。
约束:映射始终唯一。
输入描述
“密文”字符串
输出描述
明文字符串
示例1
输入:
20*19*20*
输出:
tst
说明:
翻译后的文本长度在 100 以内。
题解
基本思路是从密文字符串的末尾开始遍历,根据规则进行解密,并最终输出解密后的明文字符串。
关键点:
- 对于包含 '*' 的情况,解析前两个字符,进行相应的解密操作。
- 对于不包含 '*' 的情况,进行简单的解密操作。
- 在遍历过程中,逐步构建解密后的密码。
- 最后,反转密码字符串,因为是从末尾开始遍历的。
Python
# 读取输入文本
text = input()
# 存储解密后的密码
pwd = []
# 从字符串末尾开始遍历
i = len(text) - 1
while i >= 0:
if text[i] == '*':
# 如果当前字符是 '*',则解析前两个字符并进行解密
num = int(text[i - 2:i])
c = chr(num - 10 + ord('j'))
pwd.append(c)
i -= 3
else:
# 如果当前字符不是 '*',则进行简单解密
c = chr(ord(text[i]) - ord('1') + ord('a'))
pwd.append(c)
i -= 1
# 输出解密后的密码
print(''.join(pwd[::-1]))
相关练习题
#面经##笔试##华为od机试##华为od题库##秋招#2024华为OD机试(C卷+D卷)最新题库【超值优惠】Java/Python/C++合集
整理题解不易, 如果有帮助到您,请给点个赞 ❤️ 和收藏 ⭐,让更多的人看到。🙏🙏🙏