聊聊在私立文理读cs的两年感受

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
E轮2.5亿美元融资
K12教育独角兽一起作业
北京-诚聘人工智能/教育/大数据岗
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
码农求职神器Triplebyte:
不用海投
内推多家公司面试
把贵司招聘信息放这里
查看: 464|回复: 2
收起左侧

[算法题] Longest Consecutive Sequence

[复制链接] |试试Instant~ |关注本帖
回帖奖励 6 根萝卜 回复本帖可获得 2 根萝卜奖励! 每人限 1 次(中奖概率 90%)
lcx813 发表于 2015-6-5 21:26:41 | 显示全部楼层 |阅读模式

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

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

x
描述
Given an unsorted array of integers, find the length of the longest consecutive elements sequence.
For example, Given [100, 4, 200, 1, 3, 2], The longest consecutive elements sequence is [1,
2, 3, 4]. Return its length: 4.
Your algorithm should run in O(n) complexity.

问题
如果允许O(n log n) 的复杂度,那么可以先排序,可是本题要求O(n)。
由于序列里的元素是无序的,又要求O(n),
为什么想到用哈希表?

hli42 发表于 2015-6-6 08:06:10 | 显示全部楼层

回帖奖励 +2 根萝卜

用哈希表的原因是因为他的查询为O(1)。这里的问题是你从前往后扫的时候大的数字有可能提前出现,如果用哈希表,每次可查询x-1和x+1的key是否存在(假设不存在duplicate的情况下),如果存在就merge一下,不存在就直接添加这个key,值为1。
回复 支持 反对

使用道具 举报

全球28万学生4.7分推荐
oio14644 发表于 2015-6-8 02:29:26 | 显示全部楼层

回帖奖励 +2 根萝卜

题目要求达到O(n)的复杂度,显然是不让排序的。
实现借助了HashSet,第一遍遍历数组,将所有数字放进Set里去,第二遍遍历,
向左&&向右查每个数字所在的区间长度,查过的数字从set里即可去掉,以免再次重复这个过程。
回复 支持 反对

使用道具 举报

本版积分规则

提醒:发帖可以选择内容隐藏,部分板块支持匿名发帖。请认真读完以下全部说明:

■隐藏内容方法: [hide=200]你想要隐藏的内容比如面经[/hide]
■意思是:用户积分低于200则看不到被隐藏的内容
■可以自行设置积分值,不建议太高(200以上太多人看不到),也不建议太低(那就没必要隐藏了)
■建议只隐藏关键内容,比如具体的面试题目、涉及隐私的信息,大部分内容没必要隐藏。
■微信/QQ/电子邮件等,为防止将来被骚扰甚至人肉,以论坛私信方式发给对方最安全。
■匿名发帖的板块和方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

关闭

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

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

custom counter

GMT+8, 2018-5-21 06:08

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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