66. 两个链表的第一个公共结点

目录

链接:

题目:

思路:

代码:

图片:


链接:

原题链接

题目:

输入两个链表,找出它们的第一个公共结点。

当不存在公共节点时,返回空节点。

数据范围

链表长度 [1,2000][1,2000]。
保证两个链表不完全相同,即两链表的头结点不相同。

样例

给出两个链表如下所示:
A:        a1 → a2
                   ↘
                     c1 → c2 → c3
                   ↗            
B:     b1 → b2 → b3

输出第一个公共节点c1

思路:

我只能说这道题目我开始以为是一道错题,开始以为是一直增加指针,但是无法实现,不是算法无法实现,而是不是这样子的,思路错了,根据y总的解释,第一行是完整的第一个链表,第二行是没有重合的部分,不是全部的链表,全部的链表是第二行加上第三行对应的第一行的元素开始的后面的所有部分

首先遍历第一个链表,遍历结束之后跳转到遍历另一个链表,假设第一个链表独立的部分的长度是a,第二个链表的长度是b,两个链表的重合部分的长度是c,先遍历完第一个链表,长度是a+c,然后跳转到第二个链表,遍历到交点,总的长度是a+c+b

另一个链表开始遍历,情况是b+c+a

然后返回任意一个指针就可以了

代码:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode *findFirstCommonNode(ListNode *headA, ListNode *headB) {
        auto p=headA,q=headB;
        while(q!=p)
        {
            if(p)   p=p->next;
            else    p=headB;
            if(q)   q=q->next;
            else    q=headA;
        }
        return p;
    }
};

图片:

66. 两个链表的第一个公共结点_第1张图片

 

你可能感兴趣的:(算法刷题,链表,算法,数据结构)