【链表OJ题目】给定一个链表,返回链表开始入环的第一个节点

数据结构/算法 同时被 2 个专栏收录
12 篇文章 0 订阅
3 篇文章 0 订阅

给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 NULL

OJ链接

思路:

对于这样的一个带环链表进环之前的长度为L,环的长度为C,使用快慢指针,找到相遇的结点,结点位置距离环的入口为K,则有以下的关系:

慢指针距离:L+K

快指针距离:L+K+n*C(n代表走的环的圈数)

2*(L+K)==L+K+n*C

则 L+K==n*C

即:L==n*C-K==(n-1)*C+(C-K)

此时,我们可以得出,从相遇点出发,逆向绕环走会和从头结点出发走会在入环口相遇。

struct ListNode *detectCycle(struct ListNode *head) {
    struct ListNode*slow = head;
    struct ListNode*fast = head;

    //找到相遇结点
    while(fast!=NULL && fast->next!=NULL)
    {
        fast=fast->next->next;
        slow=slow->next;
        
        if(fast==slow)
        break;
    }
    
    //如果为空结点或着到链表尾没有找到相遇结点,则返回空
    if(fast==NULL || fast->next==NULL)
    return NULL;

    //头结点从头遍历,相遇结点从后遍历,相遇时找到入环的第一个结点
    struct ListNode*meet=fast;

    while(head != meet)
    {
        head=head->next;
        meet=meet->next;
    }

    return head;

}

 

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

参与评论 您还未登录,请先 登录 后发表或查看评论
©️2022 CSDN 皮肤主题:技术黑板 设计师:CSDN官方博客 返回首页

打赏作者

小C博客

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值