mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-26 07:18:56 +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>
 | |
| 
 |