data:image/s3,"s3://crabby-images/57e8f/57e8f65d4562f84c2dde068e49978809a6406725" alt=""
data:image/s3,"s3://crabby-images/bcd0c/bcd0c1c6923da733b1ef9390d7b711ece339664b" alt=""
data:image/s3,"s3://crabby-images/20bb4/20bb40258d02a27c7310b2dd51a18e54e9a00ce0" alt=""
data:image/s3,"s3://crabby-images/2c4c3/2c4c3f7a889dfddc05080c5ea6a69947ad6560e5" alt=""
data:image/s3,"s3://crabby-images/d2a0b/d2a0b1f9ff391808012e860763646d6ef8ca7b53" alt=""
data:image/s3,"s3://crabby-images/38ffd/38ffda6fcd0bb7a0642683896d80bc7faee65b98" alt=""
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, pB = headA, headB
while pA != pB:
# 当 pA 走完 A 链表后,跳到 B 链表
pA = pA.next if pA else headB
# 当 pB 走完 B 链表后,跳到 A 链表
pB = pB.next if pB else headA
return pA # 若相交返回交点,否则返回 None