Leetcode 142. 环形链表 II

注意的点:

1、注意里面的判断条件,虽然代码少但是其实逻辑很多。

解法:快慢指针

python 复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def detectCycle(self, head: Optional[ListNode]) -> Optional[ListNode]:

        # 快慢指针
        slow, fast = head, head

        if not head: return None

        while fast.next and fast.next.next:
            slow = slow.next
            fast = fast.next.next
            if slow == fast: break # 得放在后面
        
        if not fast.next or not fast.next.next: 
            return None

        slow = head
        while slow != fast:
            slow = slow.next
            fast = fast.next

        return fast
            
相关推荐
夜月yeyue34 分钟前
ARM内核与寄存器
arm开发·stm32·单片机·嵌入式硬件·mcu·链表
百锦再1 小时前
五种常用的web加密算法
前端·算法·前端框架·web·加密·机密
碳基学AI2 小时前
北京大学DeepSeek内部研讨系列:AI在新媒体运营中的应用与挑战|122页PPT下载方法
大数据·人工智能·python·算法·ai·新媒体运营·产品运营
独家回忆3642 小时前
每日算法-250410
算法
袖清暮雨2 小时前
Python刷题笔记
笔记·python·算法
熬夜造bug3 小时前
LeetCode Hot100 刷题笔记(1)—— 哈希、双指针、滑动窗口
笔记·leetcode·hot100
风掣长空3 小时前
八大排序——c++版
数据结构·算法·排序算法
流星白龙4 小时前
【C++算法】50.分治_归并_翻转对
c++·算法
しかし1181145 小时前
C语言队列的实现
c语言·开发语言·数据结构·数据库·经验分享·链表
Java致死6 小时前
费马小定理
算法·费马小定理