一亩三分地论坛

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

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

优步 简单的店面

[复制链接] |试试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"]
然后再给一字串例如. From 1point 3acres bbs
"thisisaword"
要找到当中在字典里面出现过的substring. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
所以应该要返回
["this", "hi", "his", "is", "is", "word"]
注意"is"被返回了两次因为确实出现了两次

面试的时候一时脑袋空白.鐣欏璁哄潧-涓浜-涓夊垎鍦
虽然觉得好像有些可以用DP或是trie的可能
但是一时半刻没有想到很好的解法
就直接暴力解

我用了一个HashSet存了字典里面的字. more info on 1point3acres.com
然后暴力搜了所有的substring去看有没有出现在set里面
加上的优化是在暴力搜索的时候考虑字典里面的最长字串长度
就可以不用去考虑过长的字串的情形
复杂度是O(N^2). Waral 鍗氬鏈夋洿澶氭枃绔,

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

评分

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算法. From 1point 3acres bbs
回复 支持 反对

使用道具 举报

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

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

使用道具 举报

liurudahai 发表于 2016-12-3 03:20:21 | 显示全部楼层
catinclay 发表于 2016-11-17 04:29
严格来说可以用kmp把复杂度降到O(m*n)...m = string.length, n = set.size.... pros and cons...
. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
对于一个SET里的这么多字符串,KMP怎么做?
回复 支持 反对

使用道具 举报

FlintKH 发表于 2016-12-20 20:27:09 | 显示全部楼层
我设想应该可以用一种高级KMP
Build a 3d matrix where the entry Wi Wj k is the index we should start in Wj if we failed to match Wi at k_th character.
Then you keep a counter for each word while iterating through the searched string, and apply the KMP method to update counters as needed...
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2017-1-20 14:14

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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