题目
注意,函数返回结果后,链表必须 保持其原始结构 。
题解
解法一 哈希表
- 首先遍历链表 headA ,并将其每个值存于哈希中,然后遍历 haedB,判断该节点是否在哈希集合中
package leetcodePlan.Base;
import java.util.HashSet;
import java.util.Set;
public class P0160 {
public static void main(String[] args) {
}
public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
Set<ListNode> visited = new HashSet<ListNode>() ;
ListNode tmp = headA ;
while(tmp != null) {
visited.add(tmp) ;
tmp=tmp.next ;
}
tmp = headB;
while(tmp != null) {
if(visited.contains(tmp)) {
return tmp ;
}
tmp = tmp.next ;
}
return null ;
}
public class ListNode {
int val;
ListNode next;
ListNode(int x) {
val = x;
next = null;
}
}
}
解法二 双指针
分情况讨论 链表 headA 和 headB 的长度分别是 m 和 n。假设链表 headA 的不相交部分有 a 个节点,链表 headB 的不相交部分有 b 个节点,两个链表相交的部分有 c 个节点,则有 a+c=m ,b+c=n。
- 若两者相交 ①
a = b 的情况下,同时到达 ② a != b 二轮循环同时到达 - 若两者不相交,同理
public ListNode fun(ListNode headA, ListNode headB) {
if(headA == null || headB ==null) {
return null ;
}
ListNode pA = headA, pB = headB ;
while(pA != pB) {
pA = pA == null ? headB : pA.next ;
pB = pB == null ? headA : pB.next ;
}
return pA ;
}
|