📣 4th of July限时特惠: VIP通行证立减$68
查看: 2818| 回复: 15
跳转到指定楼层
上一主题 下一主题
收起左侧

[二分/排序/搜索] 【求助】虚心请教经典题目摩斯密码思路解法

全局:

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
就是那道很经典的摩斯码题,
input = morse code string,
output 全部英文string的可能性。

EX: input =  “....”
      output = ["EEEE", "II", "SE", "ES", "EIE", "EEI", "IEE", "H"]

/*'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': '--..'*/  

自己写了一个,但是实在太乱了,而且有bug修不成,肯定面试的时候用不了,也不好记。
有人说用backtracking, 可是怎么判断中间的substring呢?
我的写法是造一个map,每一个substring morse code作为key,每一个value都是一个list of results corresponding to that morse code,只要查出有一个新letter的话就加进map去,只要是已经出现过的letter就update每一个list里面每一个result, 直到整条morse code扫描完毕。
可是这个做法很慢,space and time heavy。。可是就是搞不懂怎么做好。。请教论坛大神们,私信或者回复这里都行。谢谢啦

评分

参与人数 1大米 +5 收起 理由
dtccx + 5 祝早日康复

查看全部评分


上一篇:刷题打卡,每日十道LC
下一篇:35岁妈妈 想学CS 求建议
全局:
麻倉枼 发表于 2018-4-5 03:09
谢谢,好像解决了,很漂亮的解法!

:)谢谢~能否求点大米~?
回复

使用道具 举报

全局:
本帖最后由 foreveriii3 于 2018-4-4 15:39 编辑

假定trans是把morse翻译成字母的字典,如trans['.-']='A'
您好!
本帖隐藏的内容需要积分高于 120 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 120 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies




评分

参与人数 1大米 +10 收起 理由
麻倉枼 + 10 亲测有效,谢谢大神

查看全部评分

回复

使用道具 举报

推荐
14417335 2019-1-28 05:53:58 | 只看该作者
全局:
julieusc 发表于 2019-1-27 15:17
想问下楼主如果用backtracking & memorization set的话,时间和空间复杂度分别应该是多少?

我来说说我的想法。

加上memorization,DFS被叫的次数会变为 O(N^2)

但HashMap里的总共的方案,仍然会有O(2^N)个。最坏情况是
1, 1 方案
2, 2 方案
3, 4 方案
4, 8 方案
...
方案里面的每个String都会有长度N。

因此我认为总共的空间复杂度O(2^N),时间复杂度是O(N^2 + N*2^N)

补充内容 (2019-1-28 05:55):
空间复杂度漏了应为O(N*2^N)
回复

使用道具 举报

🔗
 楼主| 麻倉枼 2018-4-5 03:09:01 | 只看该作者
全局:
本帖最后由 麻倉枼 于 2018-4-4 14:44 编辑

谢谢,好像解决了,很漂亮的解法!
回复

使用道具 举报

🔗
dtccx 2018-4-5 07:36:26 | 只看该作者
全局:
你这个方法不就是挺好的 你的这个解法不就是memoization+recursion么
回复

使用道具 举报

🔗
 楼主| 麻倉枼 2018-4-5 07:41:36 | 只看该作者
全局:
本帖最后由 麻倉枼 于 2018-4-4 18:44 编辑
dtccx 发表于 2018-4-4 18:36
你这个方法不就是挺好的 你的这个解法不就是memoization+recursion么

做出bug了,做法还是DP(但是自己是DP渣),本来以为用LC 91改一下就行了,结果发现太多edge cases,最后改成一坨屎了,脑爆了做不出来
回复

使用道具 举报

🔗
 楼主| 麻倉枼 2018-4-5 07:41:52 | 只看该作者
全局:
foreveriii3 发表于 2018-4-4 18:18
:)谢谢~能否求点大米~?

已经给了,大神觉得够不够?
回复

使用道具 举报

🔗
dtccx 2018-4-5 07:43:40 | 只看该作者
全局:
麻倉枼 发表于 2018-4-5 07:41
做出bug了,本来以为用LC 91改一下就行了,结果发现太多edge cases,最后改成一坨屎了,脑爆了做不出来

lol,学累了来瓶红牛,还原你一个天才大脑。但是mountain dew更好喝诶
回复

使用道具 举报

🔗
 楼主| 麻倉枼 2018-4-5 07:44:40 | 只看该作者
全局:
dtccx 发表于 2018-4-4 18:43
lol,学累了来瓶红牛,还原你一个天才大脑。但是mountain dew更好喝诶

我做这题生病了,现在还有点脑痛。。智商捉急啊
回复

使用道具 举报

🔗
dtccx 2018-4-5 07:47:16 | 只看该作者
全局:
麻倉枼 发表于 2018-4-5 07:44
我做这题生病了,现在还有点脑痛。。智商捉急啊

摸摸,注意身体,身体是革命的本钱
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表