LeetCode:160. 相交链表

双指针法
       创建两个指针 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;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值