LeetCode_804. 唯一摩尔斯密码词

1|0题目

国际摩尔斯密码定义一种标准编码方式,将每个字母对应于一个由一系列点和短线组成的字符串, 比如: 'a' 对应 ".-"'b' 对应 "-..."'c' 对应 "-.-." ,以此类推。 为了方便,所有 26 个英文字母的摩尔斯密码表如下: [".-","-...","-.-.","-..",".","..-.","--.","....","..",".---","-.-",".-..","--","-.","---",".--.","--.-",".-.","...","-","..-","...-",".--","-..-","-.--","--.."] 给你一个字符串数组 words ,每个单词可以写成每个字母对应摩尔斯密码的组合。 例如,"cab" 可以写成 "-.-..--..." ,(即 "-.-." + ".-" + "-..." 字符串的结合)。我们将这样一个连接过程称作 单词翻译 。 对 words 中所有单词进行单词翻译,返回不同 单词翻译 的数量。   示例 1 输入: words = ["gin", "zen", "gig", "msg"] 输出: 2 解释: 各单词翻译如下: "gin" -> "--...-." "zen" -> "--...-." "gig" -> "--...--." "msg" -> "--...--." 共有 2 种不同翻译, "--...-.""--...--.". 示例 2 输入:words = ["a"] 输出:1   提示: 1 <= words.length <= 100 1 <= words[i].length <= 12 words[i] 由小写英文字母组成

2|0思路

1. 建立一个26个字母和密码的映射表 2. 将目标字符串列表的元素取出并转换 3. 弄成集合求长度

3|0示例代码

class Solution: def uniqueMorseRepresentations(self, words: List[str]) -> int: morse_tab = [".-", "-...", "-.-.", "-..", ".", "..-.", "--.", "....", "..", ".---", "-.-", ".-..", "--", "-.", "---", ".--.", "--.-", ".-.", "...", "-", "..-", "...-", ".--", "-..-", "-.--", "--.."] from string import ascii_lowercase map_morse = dict(zip(ascii_lowercase, morse_tab)) def rotate_word(word): for _ in word: return ''.join([map_morse[_] for _ in word]) trans_words = list(map(rotate_word, words)) return len(set(trans_words))
  • 执行效果也是非常的好。

    执行用时:28 ms, 在所有 Python3 提交中击败了98.44%的用户 内存消耗:14.8 MB, 在所有 Python3 提交中击败了98.83%的用户 通过测试用例: 82 / 82

4|0其他解法

  • 神奇的一行?

    ord(i) - ord('a') 映射到 MORSES 的索引 对 word 按照字符索引匹配摩尔斯密码,然后求解集合的长度
    MORSES = [".-", "-...", "-.-.", "-..", ".", "..-.", "--.", "....", "..", ".---", "-.-", ".-..", "--", "-.", "---", ".--.", "--.-", ".-.", "...", "-", "..-", "...-", ".--", "-..-", "-.--", "--.."] class Solution: def uniqueMorseRepresentations(self, words: List[str]) -> int: return len({''.join(MORSES[ord(i) - ord('a')] for i in w) for w in words})

__EOF__

本文作者博客已废弃
本文链接https://www.cnblogs.com/wuxianfeng023/p/16571170.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   博客已废弃  阅读(35)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示