leetcode hot100 160.相交链表 easy 链表双指针




链表A和B若相交:

listA = a +c

listB = b + c

a,b,c为长度

则:

a+c+b = b+c+a

说明链表A指针从头走完后,再从链表B头开始走

说明链表B指针从头走完后,再从链表A头开始走
则:他们会在相交点相遇

  • 让两个指针分别遍历 A + B 和 B + A 的路径,它们走过的总路程是相等的。
  • 如果链表相交,它们一定会在相交点相遇; (pA == pB)
  • 如果不相交,它们最终会同时指向 null。 (pA == pB == None)

即,最后都会 pA == pB

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

class Solution:
    def getIntersectionNode(self, headA: ListNode, headB: ListNode) -> Optional[ListNode]:

        if not headA or not headB:
            return None

        pa = headA
        pb = headB

        while pa != pb:
            if pa:  # A指针还在走A链表
                pa = pa.next
            else:
                pa = headB
            
            if pb:
                pb = pb.next
            else:
                pb = headA
            

        return pa
        

时间复杂度: O ( m + n ) O(m + n) O(m+n) 。其中 m m m 和 n n n 分别是两个链表的长度。最坏情况下,每个指针都会完整遍历两个链表各一次。
空间复杂度 : O ( 1 ) O(1) O(1)。只使用了两个指针,没有使用额外的存储空间。

相关推荐
leoufung8 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了8 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
样例过了就是过了12 小时前
LeetCode热题 不同路径
c++·算法·leetcode·动态规划
Navigator_Z13 小时前
LeetCode //C - 1031. Maximum Sum of Two Non-Overlapping Subarrays
c语言·算法·leetcode
如何原谅奋力过但无声15 小时前
【灵神高频面试题合集01-03】相向双指针、滑动窗口
数据结构·python·算法·leetcode
leoufung15 小时前
LeetCode 42:接雨水 —— 从“矩形法”到双指针的完整思考过程
java·算法·leetcode
_日拱一卒16 小时前
LeetCode:543二叉树的直径
算法·leetcode·职场和发展
穿条秋裤到处跑16 小时前
每日一道leetcode(2026.04.28):获取单值网格的最小操作数
算法·leetcode·职场和发展
leoufung16 小时前
LeetCode 68. Text Justification 题解:贪心与实现细节
算法·leetcode·职场和发展
洛水水17 小时前
【力扣100题】17.K 个一组翻转链表
算法·leetcode·链表