环形链表找入环点----链表OJ---三指针

https://leetcode.cn/problems/linked-list-cycle-ii/description/?envType=study-plan-v2&envId=top-100-liked

首先,需要判断是否有环,而这里我们不单纯判断是否有环,还要为下一步做准备,需要让slow指针和fast都从头结点开始走,实现逻辑就有些不同。

cpp 复制代码
struct ListNode* slow = head,*fast = head;
while(fast != NULL)//如果fast为空,说明不会有环
{
    if(fast == NULL || fast->next == NULL)
        return NULL;
    //注意这里,||两边交换位置是会出现错误的,如果交换位置,当fast == NULL时,if语句是先判断第一个条件,那么此时会空指针进行了解引用,程序崩溃
    slow = slow->next;
    fast = fast->next->next;
    if(slow == fast)
    //....找到交点,也代表有环
}

找到交点后,我们就要引入ptr指针,来和slow指针同步移动,去寻找入环点。

cpp 复制代码
//。。。。
if(slow == fast)
{
    struct ListNode* ptr = head;
    while(ptr != slow)
    {
        slow = slow->next;
        ptr = ptr->next;
    }
    return ptr;
}

最后实现代码如下:

cpp 复制代码
struct ListNode *detectCycle(struct ListNode *head) 
{
    struct ListNode* slow=head,*fast = head,*ptr = head;
    while(fast != NULL)
    {
        if(fast==NULL || fast->next == NULL)
            return NULL;
        slow = slow->next;
        fast = fast->next->next;
        if(slow == fast)
        {
            while(ptr != slow)
            {
                ptr= ptr->next;
                slow = slow->next;
            }
            return ptr;
        }
    }
    return NULL;
}
相关推荐
大白的编程日记.30 分钟前
【高阶数据结构学习笔记】高阶数据结构之B树B+树B*树
数据结构·笔记·学习
ゞ 正在缓冲99%…1 小时前
leetcode1547.切棍子的最小成本
数据结构·算法·leetcode·动态规划
2401_841495642 小时前
【LeetCode刷题】移动零
数据结构·python·算法·leetcode·数组·双指针法·移动零
hn小菜鸡2 小时前
LeetCode 153.寻找旋转排序数组中的最小值
数据结构·算法·leetcode
liu****3 小时前
12.线程同步与互斥
linux·数据结构·c++·算法·1024程序员节
屁股割了还要学3 小时前
【C++进阶】STL-string的简单实现
c语言·开发语言·数据结构·c++·学习·考研
wefg14 小时前
【数据结构】红黑树
数据结构·算法
咪咪渝粮4 小时前
112.路径总和
java·数据结构·算法
电子_咸鱼5 小时前
高阶数据结构——并查集
数据结构·c++·vscode·b树·python·算法·线性回归
xiaoye-duck5 小时前
数据结构之二叉树-堆
数据结构