1、题目
输入两个链表,找出它们的第一个公共结点。
2、例子
如、链表一 1 2 3 6 7 链表二 4 5 6 7 它们的第一个公共子结点为6。
思路
第一次遍历两个链表得到两个链表的长度,以及两个链表长度的差值error;第二次遍历两个链表时,先在较长的链表上走error步,接着分别遍历两个链表,找到的第一个相同的节点即为第一个公共节点,时间复杂度为O(m+n)。比如在上图的两个链表中,第一次遍历两个链表得到两个链表的长度为5和4,以及两个链表的差error=1;第二次遍历两个链表时,先再较长链表上走error部,即先走一步,然后分别从结点2和结点4出发同时遍历两个结点,直到找到他们的第一个公共结点6。
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};
class Solution {
public:
ListNode* FindFirstCommonNode( ListNode *pHead1, ListNode *pHead2) {
// 计算链表长度
int len1 = Lenth(pHead1);
int len2 = Lenth(pHead2);
int len = len1 - len2;
ListNode *pHeadA = pHead1;
ListNode *pHeadB = pHead2;
if(len1<len2)
{
pHeadA = pHead2;
pHeadB = pHead1;
len = len2 - len1;
}
while(len)
{
pHeadA = pHeadA->next;
len--;
}
// 查找公共结点
while(pHeadA!=nullptr)
{
if(pHeadA == pHeadB)
return pHeadA;
pHeadA = pHeadA->next;
pHeadB = pHeadB->next;
}
return nullptr;
}
int Lenth(ListNode * p)
{
int temp = 0;
while(p!=nullptr)
{
temp++;
p = p->next;
}
return temp;
}
};