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

相关推荐
_日拱一卒1 小时前
LeetCode:105从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
ʚ希希ɞ ྀ2 小时前
dp反思与总结
算法·leetcode·动态规划
菜菜的顾清寒2 小时前
力扣Hot100(23)反转链表
算法·leetcode·链表
m0_629494732 小时前
LeetCode 热题 100-----27. 合并两个有序链表
数据结构·算法·leetcode·链表
水木流年追梦3 小时前
大模型入门-RL基础
开发语言·python·算法·leetcode·正则表达式
人道领域3 小时前
【LeetCode刷题日记】617.合并二叉树(空间换安全,还是原地省内存)
java·数据结构·算法·leetcode
运筹vivo@3 小时前
3043. 最长公共前缀的长度(Leetcode 每日一题)
c++·算法·leetcode·职场和发展·每日一题
csdn_aspnet14 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
m0_6294947317 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
小羊在睡觉1 天前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go