查看: 6521| 回复: 16
跳转到指定楼层
上一主题 下一主题
收起左侧

Microsoft : 找出带环单链表的环起始节点

 
全局:

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

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
找出带环单链表的环起始节点
比如 : 1,2,3,4,5,6,3,4,5,6,3.....
3就是答案

这个题我个人认为没啥意思,太取巧了

上一篇:Microsoft : 找出相交两链表的交节点
下一篇:Amazon : 寻找最大BST子结构大小
🔗
sunstick 2011-5-18 09:50:04 | 只看该作者
全局:
回复 2# holyzz


    就好像两个人在跑道上赛跑,跑得快的跑着跑着总会比跑得慢的快一圈。。。
回复

使用道具 举报

🔗
 楼主| wwwyhx 2011-5-18 11:36:36 | 只看该作者
全局:
一般比较经典的 方法应该就是用 一个 快指针比如步进2,一个慢指针比如步进1,如果快指针能找到NULL的点说明无环;如果有一天快指针和慢指针的的指向的点相等,说明这个就是环的起点。
其他方法哈希表什么的也很常见
holyzz 发表于 2011-5-18 06:43



    不对啊,审题. 你那只能找在环中的一个节点,不能确定是第一个起始节点,看题目给的例子
回复

使用道具 举报

🔗
stephenK 2011-5-18 13:26:57 | 只看该作者
全局:
回复 2# holyzz
只能确定是否有环,没办法确定起点
回复

使用道具 举报

🔗
darksteel 2011-5-18 13:28:47 | 只看该作者
全局:
回复 4# wwwyhx
那个离答案也差的不多了。第一次相遇的时候两个指针差的是loop长度的整数倍,然假设为l,然后还是取两个指针,第一个先走l步然后两个一起每次走一步,再次相遇的地方就是起点了。
回复

使用道具 举报

🔗
 楼主| wwwyhx 2011-5-18 16:37:07 | 只看该作者
全局:
回复  wwwyhx
那个离答案也差的不多了。第一次相遇的时候两个指针差的是loop长度的整数倍,然假设为l,然后还是取两个指针,第一个先走l步然后两个一起每次走一步,再次相遇的地方就是起点了。
darksteel 发表于 2011-5-18 13:28



    不是吧,你怎么证明呢
回复

使用道具 举报

🔗
darksteel 2011-5-19 02:51:25 | 只看该作者
全局:
回复 8# holyzz
没有,你说的方法是可以的,只要像我6楼说的那样,再走一遍就能找到起点。第二遍走的时候很容易证明在loop起点两指针一定相遇,因为先走的那个比后走的领先l步,可以认为是领先k(k>=1)圈,当后走的指针到达起点的时候,先走的肯定也在起点的位置。
回复

使用道具 举报

🔗
 楼主| wwwyhx 2011-5-19 11:56:27 | 只看该作者
全局:
回复  holyzz
没有,你说的方法是可以的,只要像我6楼说的那样,再走一遍就能找到起点。第二遍走的时候很容易证明在loop起点两指针一定相遇,因为先走的那个比后走的领先l步,可以认为是领先k(k>=1)圈,当后走的指针到达起点的时候,先走的肯定也在起点的位置。
darksteel 发表于 2011-5-19 02:51



    不对,你这个找到的是第一次相交的环内节点,但是这个节点不一定就是环的起始节点(注意这个其实节点的意思)。一个很意外的方法是:当第一次找到环内的一个节点后,把这个环break掉,这样问题就变成了相交链表求交点问题了,最后需要还原。

怎么样,很无聊的算法题吧,亏微软想的出来
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

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