码迷,mamicode.com
首页 > 其他好文 > 详细

leecode [唯一摩尔斯密码词]

时间:2018-11-14 14:31:33      阅读:194      评论:0      收藏:0      [点我收藏+]

标签:tin   not   img   range   遍历   col   int   根据   bsp   

今天看到leecode [唯一摩尔斯密码词]比较有趣,但发现网页上一处错误,如下:

技术分享图片

根据原文定义"cab"对应的摩斯密码应该是"-.-..--...",已经联系leecode人员改正。

具体步骤简单分解为:
1、将26个字母及对应的摩斯密码做成字典表
2、以单词为单位去查字典表,将字母对应摩斯密码首尾连接,返回单词对应的莫斯字符串
3、自定义一个空的字典morse_words = {},对给定的单词数组遍历调用第2步,但遍历中需要判断单词
对应的莫斯字符串是否在morse_words中
对应Python代码如下:

 

def morse_decode(single_wd):
encode_ms = [".-", "-...", "-.-.", "-..", ".", "..-.", "--.", "....", "..", ".---", "-.-", ".-..", "--", "-.",
"---", ".--.", "--.-", ".-.", "...", "-", "..-", "...-", ".--", "-..-", "-.--", "--.."]
ws = [‘a‘, ‘b‘, ‘c‘, ‘d‘, ‘e‘, ‘f‘, ‘g‘, ‘h‘, ‘i‘, ‘j‘, ‘k‘, ‘l‘, ‘m‘, ‘n‘, ‘o‘, ‘p‘, ‘q‘, ‘r‘, ‘s‘, ‘t‘, ‘u‘, ‘v‘,
‘w‘, ‘x‘, ‘y‘, ‘z‘]
maps = {}
cnt = len(encode_ms)
for i in range(cnt):
maps[ws[i]] = encode_ms[i]
# print(encode_ms[i], ws[i])
# print(maps)
single_ms = ‘‘
for i in range(len(single_wd)):
char = single_wd[i]
char_morse = maps.get(char)
single_ms += char_morse
# print(w, m)
print(single_wd, single_ms)
return single_ms


def morse_distinct(words):
morse_words = {}
for w in words:
morse_word = morse_decode(single_wd=w)
print(morse_word)
if morse_word not in morse_words.values():
morse_words[w] = morse_word
print(morse_words)
return len(morse_words)


if (__name__==‘__main__‘):
# main()
words = ["gin", "zen", "gig", "msg"]
morse_decode(single_wd=‘cab‘)
cnt = morse_distinct(words=words)
print(‘distinct morse encode: ‘, cnt)

如有问题欢迎批评指正。

leecode [唯一摩尔斯密码词]

标签:tin   not   img   range   遍历   col   int   根据   bsp   

原文地址:https://www.cnblogs.com/John-Geek-2018/p/9957226.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!