python leetcode 唯一摩尔斯密码词【简单题】

该博客探讨了一个Python问题,即如何计算一组单词通过Morse编码能表示的唯一形式的数量。解题过程中,利用ord()函数将字符转换为ASCII值,并结合预定义的Morse编码字典,将每个单词转化为Morse序列,最后利用集合存储这些序列以确保唯一性,返回集合的长度作为结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.读懂题目

2. 分析,推导解法,产生思路。

解题思路:

set集合元素不重复。ord():将字符转换成对应的 ASCII 数值,或者 Unicode 数值

3.代码实现

class Solution(object):
    def uniqueMorseRepresentations(self, words):
        """
        :type words: List[str]
        :rtype: int
        """
        # ord():将字符转换成对应的 ASCII 数值,或者 Unicode 数值
        # set集合元素不重复。
        dict = [".-","-...","-.-.","-..",".","..-.","--.","....","..",".---","-.-",".-..","--","-.","---",".--.","--.-",".-.","...","-","..-","...-",".--","-..-","-.--","--.."]
        words_set ={''.join(dict[ord(c)-ord('a')] for c in word) for word in words}
        return len(words_set)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值