《数据科学面试40+真题讲解》,K神本年度最后一次开课


一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
码农求职神器Triplebyte:
不用海投,内推你去多家公司面试
Airbnb 数据科学职位
in analytics and inference
天天打游戏、照样领工资,
你要不要来?
把贵司招聘信息放这里
查看: 1708|回复: 7
收起左侧

优步 简单的店面

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

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

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

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

x
刚刚面的店面需要在codepair里面run test case的
题目大概是这样
先给你一个字典
["this", "hi", "his", "is", "word"]
然后再给一字串例如-google 1point3acres
"thisisaword"
要找到当中在字典里面出现过的substring
所以应该要返回
. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷["this", "hi", "his", "is", "is", "word"]
注意"is"被返回了两次因为确实出现了两次
.鐣欏璁哄潧-涓浜-涓夊垎鍦
面试的时候一时脑袋空白
虽然觉得好像有些可以用DP或是trie的可能. From 1point 3acres bbs
但是一时半刻没有想到很好的解法
就直接暴力解.鐣欏璁哄潧-涓浜-涓夊垎鍦

我用了一个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字串掃過一遍. more info on 1point3acres.com
對吧
看來該好好了解一下KMP算法
回复 支持 反对

使用道具 举报

liurudahai 发表于 2016-12-3 03:20:10 | 显示全部楼层
tj474474 发表于 2016-11-17 09:17
所以是把字典裡的字一個一個拿LC裡面那道strStr()的作法對input字串掃過一遍
對吧
看來該好好了解一下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...
回复 支持 反对

使用道具 举报

xjob2017spring 发表于 2017-2-6 12:29:32 | 显示全部楼层
感觉用trie还是O(n^2)所以面试官不在乎

另外dp应该不太适用于print all的情况吧(好像这么generalize也不对)
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2017-11-21 20:14

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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