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)
  • 快慢指针的优势
    • 解决链表中常见的问题:例如找中点、判断环、回文链表等,常常用到快慢指针。
    • 高效的空间利用:只使用常数空间,避免了使用额外的空间(如栈或哈希表等)。
相关推荐
tony365几秒前
强化学习 A2C算法
人工智能·算法
Tess_Blingbling13 分钟前
力扣Hoot100 第一天 | 哈希3题
leetcode·哈希算法·散列表
好易学·数据结构27 分钟前
可视化图解算法51:寻找第K大(数组中的第K个最大的元素)
数据结构·python·算法·leetcode·力扣·牛客网·堆栈
电院工程师32 分钟前
轻量级密码算法PRESENT的C语言实现(无第三方库)
c语言·算法·安全·密码学
bubiyoushang8882 小时前
MATLAB实现图像纹理特征提取
人工智能·算法·matlab
了不起的杰2 小时前
[算法][好题分享][第三大的数][最短无序子数组]
算法
a东方青2 小时前
[蓝桥杯 2023 国 B] AB 路线 (BFS)
c++·算法·职场和发展·蓝桥杯·宽度优先
依然易冷2 小时前
【LLM Tool Learning】论文分享: Chain-of-Tools
算法
Once_day2 小时前
代码训练LeetCode(33)字符串首次匹配
算法·leetcode·c
jndingxin2 小时前
OpenCV CUDA 模块光流计算------稀疏光流算法类SparsePyrLKOpticalFlow
人工智能·opencv·算法