题解——相交链表(力扣160 easy)

160. 相交链表

算法思路

  1. 核心思想

    • 使用两个指针 pApB,分别从 headAheadB 开始遍历。
    • pA 遍历到链表 A 的末尾时,跳转到链表 B 的头节点;当 pB 遍历到链表 B 的末尾时,跳转到链表 A 的头节点。
    • 如果两个链表相交,pApB 最终会在相交节点相遇;如果不相交,pApB 会同时到达 None
  2. 具体步骤

    • 初始化 pA = headApB = headB
    • pA != pB 时:
      • 如果 pA 为空,跳转到 headB;否则继续遍历 pA.next
      • 如果 pB 为空,跳转到 headA;否则继续遍历 pB.next
    • 返回 pA(即相交节点)。
  3. 关键点

    • 通过跳转指针的方式,确保两个指针遍历的总长度相同。
    • 时间复杂度为 O(m + n),空间复杂度为 O(1)
python 复制代码
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def getIntersectionNode(self, headA, headB):
        if not headA or not headB:
            return None
        
        pA, pB = headA, headB
        while pA != pB:
            pA = headB if not pA else pA.next
            pB = headA if not pB else pB.next
        
        return pA

题解里看到的图解,很清晰

相关推荐
xiaofann_19 分钟前
【数据结构】二叉树概念及代码
数据结构
GeekPMAlex32 分钟前
RAG 02 多模态检索 多维主键
算法
CoovallyAIHub38 分钟前
只有2MB,却能跑满277FPS?专为无人机小目标打造!
深度学习·算法·计算机视觉
金宗汉40 分钟前
文明存续的时间博弈:论地球资源枯竭临界期的技术突围与行动紧迫性
大数据·人工智能·笔记·算法·观察者模式
YLCHUP1 小时前
题解:P4447 [AHOI2018初中组] 分组
开发语言·数据结构·c++·经验分享·算法·贪心算法·抽象代数
过往入尘土1 小时前
关于逻辑回归的相关知识大全
算法·机器学习·逻辑回归
John.Lewis1 小时前
C语言数据结构(7)贪吃蛇项目2.贪吃蛇项目实现
c语言·数据结构·算法
洛生&1 小时前
区间调度问题
算法
三小尛2 小时前
C++友元
开发语言·c++·算法
小指纹2 小时前
河南萌新联赛2025第(三)场:河南理工大学【补题】
数据结构·c++·算法·macos·ios·objective-c·cocoa