链表 寻找链表中环的起点

给定一个带有环的单链表,通过双指针法寻找环的起点。使用快慢指针,快指针每次移动两步,慢指针移动一步。当它们在环内相遇时,将快指针重置到起点,之后两者每次移动一步,相遇点即为环的起点。
摘要由CSDN通过智能技术生成

给定一个单链表,若该链表有环,返回环的起点,若没有,返回NULL

基本思路:

每遇到一个节点,计数器++ ,当遇到访问次数为2时,返回该节点,否则在循环结束前还没有找到,则返回NULL



class Solution {
public:
    ListNode* EntryNodeOfLoop(ListNode* pHead)
    {
        if(!pHead) 
            return null;
        map<ListNode*,int> flag;//统计节点访问次数
        while(pHead)
        {
            if(++flag[pHead]==2)
            return pHead;
            pHead=pHead->next;
        }
        return null;
        
    }
};

进阶思路:双指针思路,

  • 设置一快一慢双指针,初始化双指针指向起点
  • 每次快指针移动2步,慢指针移动1步
  • 若有环,则一定在环中相遇
  • 设置快指针到起点,2个指针每次移动1步,相遇时即为环起点 

证明:

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值