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

相关推荐
想吃火锅10053 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
小林ixn4 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
菜鸟‍6 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展
退休倒计时7 小时前
【每日一题】LeetCode 142. 环形链表 II TypeScript
算法·leetcode·链表·typescript
sjsjs1111 小时前
力扣3558. 给边赋权值的方案数 I
算法·leetcode·职场和发展
花间相见11 小时前
【LeetCode01】—— 无重复字符的最长子串:滑动窗口经典题详解
python·算法·leetcode
言存13 小时前
力扣热题283 移动零
数据结构·算法·leetcode
洛水水15 小时前
【力扣100题】80.寻找旋转排序数组中的最小值
数据结构·算法·leetcode
洛水水15 小时前
【力扣100题】82.有效的括号
c++·算法·leetcode
legend050709ComeON15 小时前
常见面试题-leetcode
数据结构·算法·leetcode