给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。
图示两个链表在节点 c1 开始相交:
题目数据 保证 整个链式结构中不存在环。
注意,函数返回结果后,链表必须 保持其原始结构 。
力扣解答
1穷举法
2如果用哈希表的话 时间复杂度为O(m+n) 空间复杂度为O(m)或O(n)
判断两个链表是否相交,可以使用哈希集合存储链表节点。
首先遍历链表 \textit{headA}headA,并将链表 \textit{headA}headA 中的每个节点加入哈希集合中。然后遍历链表 \textit{headB}headB,对于遍历到的每个节点,判断该节点是否在哈希集合中:
如果当前节点不在哈希集合中,则继续遍历下一个节点;
如果当前节点在哈希集合中,则后面的节点都在哈希集合中,即从当前节点开始的所有节点都在两个链表的相交部分,因此在链表 \textit{headB}headB 中遍历到的第一个在哈希集合中的节点就是两个链表相交的节点,返回该节点。
public class Solution{
public ListNode getIntersectionNode(ListNode headA,ListNode headB) {
Set<ListNode>Visited=new HashSst<ListNode>();
ListNode temp =headA;
while(temp!=null) {
visited.add(temp);
temp=temp.next;
}
temp=headB;
while(temp!=null) {
if (visited.contains(temp)) {
return temp;
}
temp=temp.next;
}
return null;
}
}
3使用双指针:当两个指针指向同一个的时候,即为所求。
4或者 先遍历两个链表,然后用m-n。然后长的从m-n位置开始,短的从初始位置开始,遍历直到指向同一个节点。