数据结构之单链表之环形链表

1.题目

题目:给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。

2.分析

首先,我们应该判断链表是否有环,这个可以根据我的上一篇文章的快慢指针来判断。

bool hasCycle(struct ListNode* head) {
    struct ListNode* slow = head;//慢指针
    struct ListNode* fast = head;//快指针
    while (fast && fast->next) {
       slow = slow->next;//慢指针走一步
        fast = fast->next->next;//快指针走两步
        if (slow == fast) {
            return true;//两个指针相遇则有环
        }               //证明过程可以看上一篇博客
        
    }
    return false;
}

其次,我们如何寻找入环的第一个节点呢?
这里有一个理论,我们先使用,稍后做证明。
理论:头节点到入环的第一个节点的距离等于快慢指针相遇时的位置到入环的第一个节点的距离
在这里插入图片描述

证明
在这里插入图片描述
所以,题目的完整答案

struct ListNode *detectCycle(struct ListNode *head) {
    struct ListNode*slow = head;
    struct ListNode*fast = head;
    while(fast && fast->next)
    {
        slow = slow->next;
        fast = fast->next->next;
        if(slow == fast)//找到快慢指针的相遇点
        {
            struct ListNode*meet = slow;
            struct ListNode*cur = head;
            while(cur)
            {
                
                if(meet==cur)
                return meet;
                meet = meet->next;//走向环的第一个节
                cur = cur->next;//走向环的第一个节点
            }
        }
    }
    return NULL;
}

如果发现有什么不对的地方,或者不理解的地方,可以评论我哟!

相关推荐

  1. 数据结构 循环 双向

    2024-05-10 12:58:04       67 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-10 12:58:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-10 12:58:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-10 12:58:04       82 阅读
  4. Python语言-面向对象

    2024-05-10 12:58:04       91 阅读

热门阅读

  1. [力扣题解] 216. 组合总和 III

    2024-05-10 12:58:04       36 阅读
  2. PostgreSQL的pg_dump和 pg_dumpall 异同点

    2024-05-10 12:58:04       37 阅读
  3. 使用Python实现循环神经网络(RNN)的博客教程

    2024-05-10 12:58:04       30 阅读
  4. xml怎么用【C#,XML】

    2024-05-10 12:58:04       37 阅读
  5. (十二)C语言的结构体

    2024-05-10 12:58:04       35 阅读
  6. 设计模式——观察者模式(Observer)

    2024-05-10 12:58:04       31 阅读
  7. 责任链模式案例

    2024-05-10 12:58:04       29 阅读
  8. Linux下添加自己的服务脚本(service)

    2024-05-10 12:58:04       33 阅读