首页 > 其他分享 >[leetcode每日一题]2.1

[leetcode每日一题]2.1

时间:2023-02-01 14:31:58浏览次数:59  
标签:word ord 每日 leetcode key ans 2.1 对照表 message

​2325. 解密消息​

给你字符串 ​​key​​ 和 ​​message​​ ,分别表示一个加密密钥和一段加密消息。解密 ​​message​​ 的步骤如下:

  1. 使用 ​​key​​ 中 26 个英文小写字母第一次出现的顺序作为替换表中的字母 顺序 。
  2. 将替换表与普通英文字母表对齐,形成对照表。
  3. 按照对照表 替换 ​​message​​ 中的每个字母。
  4. 空格 ​​' '​​ 保持不变。
  • 例如,​​key = "happy boy"​​(实际的加密密钥会包含字母表中每个字母 至少一次),据此,可以得到部分对照表(​​'h' -> 'a'​​、​​'a' -> 'b'​​、​​'p' -> 'c'​​、​​'y' -> 'd'​​、​​'b' -> 'e'​​、​​'o' -> 'f'​​)。

返回解密后的消息。

示例 1:

[leetcode每日一题]2.1_Python

输入:key = "the quick brown fox jumps over the lazy dog", message = "vkbs bs t suepuv"
输出:"this is a secret"
解释:对照表如上图所示。
提取 "the quick brown fox jumps over the lazy dog" 中每个字母的首次出现可以得到替换表。

示例 2:

[leetcode每日一题]2.1_Python_02

输入:key = "eljuxhpwnyrdgtqkviszcfmabo", message = "zwx hnfx lqantp mnoeius ycgk vcnjrdb"
输出:"the five boxing wizards jump quickly"
解释:对照表如上图所示。
提取 "eljuxhpwnyrdgtqkviszcfmabo" 中每个字母的首次出现可以得到替换表。

提示:

  • ​26 <= key.length <= 2000​
  • ​key​​ 由小写英文字母及 ​​' '​​ 组成
  • ​key​​ 包含英文字母表中每个字符(​​'a'​​ 到 ​​'z'​​)至少一次
  • ​1 <= message.length <= 2000​
  • ​message​​ 由小写英文字母和 ​​' '​​ 组成

Solution

简单模拟即可。

代码(Python)

class Solution:
def decodeMessage(self, key: str, message: str) -> str:
num = 0
t = [0]*26
cnt = 0
for word in key:
if word != ' ' and not (1<<(ord(word)-ord('a'))) & num:
num |= 1<<(ord(word)-ord('a'))
t[ord(word)-ord('a')] = cnt
cnt += 1
ans = ''
for word in message:
if word == ' ':
ans += word
else:
ans += chr(t[ord(word) - ord('a')] + ord('a'))
return ans

标签:word,ord,每日,leetcode,key,ans,2.1,对照表,message
From: https://blog.51cto.com/u_15763108/6031582

相关文章