| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2190 人关注过本帖
标题:一个面试题
只看楼主 加入收藏
missiyou
Rank: 5Rank: 5
等 级:贵宾
威 望:16
帖 子:531
专家分:218
注 册:2007-10-9
结帖率:100%
收藏
 问题点数:0 回复次数:13 
一个面试题
问,“如何检测链表是循环链表”
如果长度为N的链表如何检测
如果允许做标记,如何检测,
最难的 如果链表的循环在任意位置,任意长度,如何检测是循环链表。
恩,就是这道题,
搜索更多相关主题的帖子: 面试 
2007-12-09 22:58
ranchgirl
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2007-12-8
收藏
得分:0 
Use two pointers, one pointer one-step-at-a-time, one pointer two-steps-at-a-time. Check they are equal or not each time.

If cycle exists, they will meet eventually.

All your problems are solved this way!
2007-12-10 09:33
ranchgirl
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2007-12-8
收藏
得分:0 
This is a real interview question, my friend got this one from AA.
2007-12-10 09:35
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
设定一标记一结点,从这结点开始,只要重新遍历到该结点则表示有循环。

倚天照海花无数,流水高山心自知。
2007-12-10 10:01
ranchgirl
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2007-12-8
收藏
得分:0 
原帖由 [bold][underline]nuciewth[/underline][/bold] 于 2007-12-10 10:01 发表 [url=http://bbs.][/url]
设定一标记一结点,从这结点开始,只要重新遍历到该结点则表示有循环。


[size=4]Wrong!!![/size]

Since this might 标记 on the point before cycle happens.

Just think the letter b, circle does exist, but if you mark at the beginning will be garanteed to fail.

[[italic] 本帖最后由 ranchgirl 于 2007-12-10 10:34 编辑 [/italic]]
2007-12-10 10:30
blueboy82006
Rank: 5Rank: 5
来 自:幻想世界
等 级:贵宾
威 望:16
帖 子:1227
专家分:57
注 册:2007-7-23
收藏
得分:0 
回复 5# 的帖子
哦,长见识了啊

2007-12-10 12:32
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
"如何检测链表是循环链表”

The question is how to examine  the link list  make a circle,not  to judge the link list have a circle.

倚天照海花无数,流水高山心自知。
2007-12-10 15:11
ranchgirl
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2007-12-8
收藏
得分:0 
最难的 如果链表的循环在任意位置,任意长度,如何检测是循环链表。


To  nuciewth:

Did you even read the entire question?????
2007-12-10 15:17
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
最难的 如果链表的循环在任意位置,任意长度,如何检测是循环链表。

那就不叫循环链表.
我所学到的循环链表就是头尾相接,组成一个圈.而不是一个带环的链表.

倚天照海花无数,流水高山心自知。
2007-12-10 16:48
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
如果真的要检测,只要设定已经被访问标记即可.(必要时可以修改data域)

倚天照海花无数,流水高山心自知。
2007-12-10 16:50
快速回复:一个面试题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025146 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved