定个小目标之刷LeetCode热题(20)

这题与上一题有一点不同,上一题是判断链表是否存在环,这题是寻找入环的第一个节点,有一个规则是这样的,在存在环的情况下,运用快慢指针判断是否有环结束时,把快指针指向头结点,慢指针不变,然后循环快慢指针每次只走一步,最终会在入环的第一个节点相遇,代码如下

java 复制代码
public class Solution {
    public ListNode detectCycle(ListNode head) {
        if (head == null || head.next == null) {
            return null;
        }
        ListNode slow = head, fast = head;
        while (fast != null) {
            slow = slow.next;
            if (fast.next != null) {
                fast = fast.next.next;
            } else {
                return null;
            }
            // 如果在快慢指针规则移动指针存在slow == fast说明存在环
            if (slow == fast) {
                // 此时需要寻找入环的第一个节点,将fast指向头节点
                fast = head;
                // 然后快指针和慢指针各移动一次,最终会在入环的第一个节点相遇
                while (slow != fast) {
                    slow = slow.next;
                    fast = fast.next;
                }
                return fast;
            }
        }
        return null;
    }
}

题目链接:题单 - 力扣(LeetCode)全球极客挚爱的技术成长平台

相关推荐
小王努力学编程1 小时前
高并发内存池(二):项目的整体框架以及Thread_Cache的结构设计
开发语言·c++·学习·算法
补三补四1 小时前
遗传算法(GA)
人工智能·算法·机器学习·启发式算法
dot to one2 小时前
C++ 渗透 数据结构中的二叉搜索树
数据结构·c++·算法·visual studio
蓝婷儿2 小时前
前端面试每日三题 - Day 29
前端·面试·职场和发展
好易学·数据结构3 小时前
可视化图解算法36: 序列化二叉树-I(二叉树序列化与反序列化)
数据结构·算法·leetcode·二叉树·力扣·序列化·牛客
uiop_uiop_uiop3 小时前
Xcode16.3配置越狱开发环境
职场和发展·蓝桥杯
_AaRong_3 小时前
经典密码学算法实现
算法·密码学
孙同学_4 小时前
【递归,搜索与回溯算法篇】专题(一) - 递归
算法·leetcode
Tummer83635 小时前
C语言与C++的区别
c语言·c++·算法
MSTcheng.5 小时前
【数据结构】算法的复杂度
数据结构·算法