LeetCode_804. 唯一摩尔斯密码词

题目

国际摩尔斯密码定义一种标准编码方式,将每个字母对应于一个由一系列点和短线组成的字符串, 比如:

'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] 由小写英文字母组成

思路

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

示例代码

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
    

其他解法

  • 神奇的一行?

    将 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})
    
posted @ 2022-08-10 09:36  博客已废弃  阅读(54)  评论(0)    收藏  举报