leetcode_链表 876.链表的中间节点

876.链表的中间节点

  • 给你单链表的头结点 head ,请你找出并返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点。
  • 思路:快慢指针,创建两个指针fast和slow,fast指针每次移动两步,slow指针每次移动一步,这样当fast指针指向列表以外的值的时候(退出循环的时候),slow指针正好指向链表的中间节点。
bash 复制代码
- # Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution(object):
    def middleNode(self, head):
        """
        :type head: Optional[ListNode]
        :rtype: Optional[ListNode]
        """
        if not head or not head.next:
        # 若链表不存在或只有一个节点时,返回head
        	return head
        	
        fast, slow = head, head
        while fast and fast.next:
            fast = fast.next.next
            slow = slow.next
        return slow
  • 时间复杂度:O(n)
  • 空间复杂度::O(1)
  • 快慢指针的优势
    • 解决链表中常见的问题:例如找中点、判断环、回文链表等,常常用到快慢指针。
    • 高效的空间利用:只使用常数空间,避免了使用额外的空间(如栈或哈希表等)。
相关推荐
scx201310041 分钟前
20251214 字典树总结
算法·字典树
leiming63 分钟前
MobileNetV4 (MNv4)
开发语言·算法
YGGP18 分钟前
【Golang】LeetCode 136. 只出现一次的数字
算法·leetcode
YGGP26 分钟前
【Golang】LeetCode 169. 多数元素
算法·leetcode
顾安r29 分钟前
11.20 脚本网页 数学分支
算法·数学建模·html
少许极端33 分钟前
算法奇妙屋(二十)-回文子串/子序列问题(动态规划)
java·算法·动态规划·图解·回文串·回文序列
天赐学c语言40 分钟前
12.20 - 反转链表II && 传值和传地址的区别
数据结构·c++·算法·链表·leecode
如意鼠42 分钟前
大模型教我成为大模型算法工程师之day20: 预训练语言模型 (Pre-trained Language Models)
人工智能·算法·语言模型
_OP_CHEN42 分钟前
【算法基础篇】(三十六)图论基础之拓扑排序:从原理到实战,搞定 DAG 图的 “先后次序” 难题
c++·算法·蓝桥杯·图论·拓扑排序·算法竞赛·acm/icpc
良木生香1 小时前
【诗句结构-初阶】详解栈和队列(2)---队列
c语言·数据结构·算法·蓝桥杯