双指针法
创建两个指针 pA和 pB,分别初始化为链表 A 和 B 的头结点。然后让它们向后逐结点遍历。
当 pA 到达链表的尾部时,将它重定位到链表 B 的头结点 , 类似的,当 pB 到达链表的尾部时,将它重定位到链表 A 的头结点。
若在某一时刻 pA 和 pB 相遇,则 该点为相交结点。
想弄清楚为什么这样可行, 可以考虑以下两个链表: A={1,3,5,7,9,11} 和 B={2,4,9,11},相交于结点 9。 由于 B.length (=4) < A.length (=6),pB 比 pA 少经过 22 个结点,会先到达尾部。将 pB 重定向到 A 的头结点,pA 重定向到 B 的头结点后,pB 要比 pA 多走 2 个结点。因此,它们会同时到达交点。
如果两个链表存在相交,它们末尾的结点必然相同。因此当 到达链表结尾时,记录下链表对应的元素。若最后元素不相同,则两个链表不相交。但是值得注意的是,在本题中连个链表必然是相交的。
复杂度分析
时间复杂度 : O(m+n)。
空间复杂度 : O(1)。
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode *getIntersectionNode(ListNode *headA, ListNode *headB)
{
ListNode* a=headA,*b=headB;
while(a!=b)
{
if(a!=NULL)
{
a=a->next;
}
else
{
a=headB;
}
if(b!=NULL)
{
b=b->next;
}
else
{
b=headA;
}
}
return a;
}
};