mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-25 17:50:26 +08:00
33 lines
2.3 KiB
HTML
33 lines
2.3 KiB
HTML
<p>Given two (singly) linked lists, determine if the two lists intersect. Return the inter­ secting node. Note that the intersection is defined based on reference, not value. That is, if the kth node of the first linked list is the exact same node (by reference) as the jth node of the second linked list, then they are intersecting.</p>
|
|
|
|
|
|
|
|
<p><strong>Example 1: </strong></p>
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
<strong>Input: </strong>intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA = 2, skipB = 3
|
|
|
|
<strong>Output: </strong>Reference of the node with value = 8
|
|
|
|
<strong>Input Explanation:</strong> The intersected node's value is 8 (note that this must not be 0 if the two lists intersect). From the head of A, it reads as [4,1,8,4,5]. From the head of B, it reads as [5,0,1,8,4,5]. There are 2 nodes before the intersected node in A; There are 3 nodes before the intersected node in B.</pre>
|
|
|
|
|
|
|
|
<p><strong>Example 2: </strong></p>
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
<strong>Input: </strong>intersectVal = 2, listA = [0,9,1,2,4], listB = [3,2,4], skipA = 3, skipB = 1
|
|
|
|
<strong>Output: </strong>Reference of the node with value = 2
|
|
|
|
<strong>Input Explanation:</strong> The intersected node's value is 2 (note that this must not be 0 if the two lists intersect). From the head of A, it reads as [0,9,1,2,4]. From the head of B, it reads as [3,2,4]. There are 3 nodes before the intersected node in A; There are 1 node before the intersected node in B.</pre>
|
|
|
|
|
|
|
|
<p><strong>Example 3: </strong></p>
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
<strong>Input: </strong>intersectVal = 0, listA = [2,6,4], listB = [1,5], skipA = 3, skipB = 2
|
|
|
|
<strong>Output: </strong>null
|
|
|
|
<strong>Input Explanation:</strong> From the head of A, it reads as [2,6,4]. From the head of B, it reads as [1,5]. Since the two lists do not intersect, intersectVal must be 0, while skipA and skipB can be arbitrary values.
|
|
|
|
<strong>Explanation:</strong> The two lists do not intersect, so return null.</pre>
|
|
|
|
|
|
|
|
<p><b>Notes:</b></p>
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
<li>If the two linked lists have no intersection at all, return <code>null</code>.</li>
|
|
|
|
<li>The linked lists must retain their original structure after the function returns.</li>
|
|
|
|
<li>You may assume there are no cycles anywhere in the entire linked structure.</li>
|
|
|
|
<li>Your code should preferably run in O(n) time and use only O(1) memory.</li>
|
|
|
|
</ul>
|
|
|