找到链表中环的起始点

本文介绍了一种使用快慢指针的方法来判断链表是否存在环,并在存在环的情况下找到环的起点。通过两次遍历,一次判断是否存在环,另一次确定环的起点位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以前想了好几次没想明白,早上拿笔纸一画就看出来了;

设置slow,fast两个指针,slow每次移动一步,fast每次移动两步;若fast结束前与slow重合则说明有环,若未重合即结束则说明没有环;

第一次重合时,假设从head到环起始位置距离为k,slow移动了n步,则slow在环中移动了n-k步,fast在环中移动了2n-k步;距离差n为环长度的倍数;

所以slow再移动k步将到达环的起始位置;这时再从head出发一个finder指针,移动k步恰好也到了环的起始位置,所以当slow==finder的位置即为所求;

代码:

 1     public ListNode detectCycle(ListNode head) {
 2         if(head == null) return null;
 3         ListNode fast = head;
 4         ListNode slow = head;
 5         do{
 6             slow = slow.next;
 7             fast = fast.next;
 8             if(slow==null || fast==null) return null;
 9             fast = fast.next;
10             if(fast==null) return null;
11         }while(fast != slow);
12         
13         ListNode finder = head;
14         while(finder != slow){
15             finder = finder.next;
16             slow = slow.next;
17         }
18         return finder;
19     }

 

转载于:https://www.cnblogs.com/ibuki/p/4836275.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值