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

1.题目

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

2.分析

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

c 复制代码
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;
}

其次,我们如何寻找入环的第一个节点呢?

这里有一个理论,我们先使用,稍后做证明。
理论:头节点到入环的第一个节点的距离等于快慢指针相遇时的位置到入环的第一个节点的距离

复制代码

证明

所以,题目的完整答案

c 复制代码
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;
}

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

相关推荐
云泽8087 小时前
数据结构之单链表和环形链表的应用(二)-
数据结构
dragoooon348 小时前
[优选算法专题二滑动窗口——串联所有单词的子串]
数据结构·c++·学习·算法·leetcode·学习方法
Pocker_Spades_A9 小时前
论文精读(五):面向链接预测的知识图谱表示学习方法综述
人工智能·链表·知识图谱
阿让啊16 小时前
C语言strtol 函数使用方法
c语言·数据结构·c++·单片机·嵌入式硬件
superlls19 小时前
(算法 哈希表)【LeetCode 349】两个数组的交集 思路笔记自留
java·数据结构·算法
Ripple1231220 小时前
数据结构:顺序表与链表
数据结构·链表
一个响当当的名号21 小时前
B树,B+树,B*树(无代码)
数据结构·b树
古译汉书1 天前
嵌入式铁头山羊stm32-ADC实现定时器触发的注入序列的单通道转换-Day26
开发语言·数据结构·stm32·单片机·嵌入式硬件·算法
野犬寒鸦1 天前
力扣hot100:相交链表与反转链表详细思路讲解(160,206)
java·数据结构·后端·算法·leetcode
GalaxyPokemon1 天前
LeetCode - 1089. 复写零
数据结构