一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 423|回复: 5
收起左侧

优步 简单的店面

[复制链接] |试试Instant~ |关注本帖
tj474474 发表于 2016-11-17 04:17:04 | 显示全部楼层 |阅读模式

2016(10-12月) 码农类 硕士 全职@Uber - 网上海投 - 技术电面 |Otherfresh grad应届毕业生

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

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
刚刚面的店面需要在codepair里面run test case的
题目大概是这样
先给你一个字典
["this", "hi", "his", "is", "word"]
然后再给一字串例如
"thisisaword"
要找到当中在字典里面出现过的substring
所以应该要返回
["this", "hi", "his", "is", "is", "word"]
注意"is"被返回了两次因为确实出现了两次. 1point 3acres 璁哄潧

面试的时候一时脑袋空白.1point3acres缃
虽然觉得好像有些可以用DP或是trie的可能
但是一时半刻没有想到很好的解法
就直接暴力解

我用了一个HashSet存了字典里面的字
然后暴力搜了所有的substring去看有没有出现在set里面
加上的优化是在暴力搜索的时候考虑字典里面的最长字串长度
就可以不用去考虑过长的字串的情形
复杂度是O(N^2). 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴

面试官好像很喜欢我的解法
大家讨论看看还有没有什么更好的解法吗

评分

1

查看全部评分

xCookies 发表于 2016-11-17 04:21:39 | 显示全部楼层
一般要输出所有可能情况的,DP解决不了的吧,你这个方法挺好的,没问题啊
回复 支持 1 反对 0

使用道具 举报

catinclay 发表于 2016-11-17 04:29:12 | 显示全部楼层
严格来说可以用kmp把复杂度降到O(m*n)...m = string.length, n = set.size.... pros and cons...
回复 支持 反对

使用道具 举报

 楼主| tj474474 发表于 2016-11-17 09:17:56 | 显示全部楼层
catinclay 发表于 2016-11-17 04:29
严格来说可以用kmp把复杂度降到O(m*n)...m = string.length, n = set.size.... pros and cons...

所以是把字典裡的字一個一個拿LC裡面那道strStr()的作法對input字串掃過一遍
對吧
看來該好好了解一下KMP算法
.1point3acres缃
回复 支持 反对

使用道具 举报

liurudahai 发表于 3 天前 | 显示全部楼层
tj474474 发表于 2016-11-17 09:17
所以是把字典裡的字一個一個拿LC裡面那道strStr()的作法對input字串掃過一遍
對吧
看來該好好了解一下K ...

对于一个SET里的这么多字符串,KMP怎么做?
回复 支持 反对

使用道具 举报

liurudahai 发表于 3 天前 | 显示全部楼层
catinclay 发表于 2016-11-17 04:29
严格来说可以用kmp把复杂度降到O(m*n)...m = string.length, n = set.size.... pros and cons...
. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
对于一个SET里的这么多字符串,KMP怎么做?
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-6 09:08

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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