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)。只使用了两个指针,没有使用额外的存储空间。

相关推荐
一叶落43816 小时前
题目:15. 三数之和
c语言·数据结构·算法·leetcode
big_rabbit050218 小时前
[算法][力扣222]完全二叉树的节点个数
数据结构·算法·leetcode
张李浩18 小时前
Leetcode 15三题之和
算法·leetcode·职场和发展
x_xbx19 小时前
LeetCode:206. 反转链表
算法·leetcode·链表
abant219 小时前
leetcode 138 复制随机链表
算法·leetcode·链表
做怪小疯子21 小时前
Leetcode刷题——8.重叠区间
算法·leetcode·职场和发展
_饭团1 天前
指针核心知识:5篇系统梳理3
c语言·数据结构·算法·leetcode·面试·学习方法·改行学it
阿Y加油吧1 天前
力扣打卡——day01
java·算法·leetcode
Tisfy1 天前
LeetCode 1727.重新排列后的最大子矩阵:枚举矩形底边是哪一行 + 排序
算法·leetcode·矩阵
_饭团1 天前
指针核心知识:5篇系统梳理2
c语言·笔记·学习·leetcode·面试·改行学it