题目描述
如果有公共结点肯定是在后面重叠,且后面部分都是共同的。
方法1:先计算出两个链表的长度,可以让比较长的先走两个链表长度之差的步数,两个再一起走。
方法2:不同部分为a, 和b,公共部分为c;a + c + b = b + c + a;让两个一起走,a走到头就转向b, b走到头转向a,则在公共部分相遇。
C++ 代码
class Solution {
public:
ListNode *findFirstCommonNode(ListNode *headA, ListNode *headB) {
auto p = headA, q = headB;
int la = 0, lb = 0;
for (auto t = headA; t; t = t->next) la ++;
for (auto t = headB; t; t = t->next) lb ++;
int k = la - lb;
if (la < lb) {
p = headB, q = headA;
k = lb - la;
}
while(k --) {
p = p->next;
}
while(p) {
if (p == q) return p;
p = p->next;
q = q->next;
}
return nullptr;
}
};
C++ 代码
class Solution {
public:
ListNode *findFirstCommonNode(ListNode *headA, ListNode *headB) {
auto p = headA, q = headB;
while(p != q) {
if(p) p = p->next;
else p = headB;
if (q) q = q->next;
else q = headA;
}
return p;
}
};
还有一种情况,两个链表都有环。你的方法在计算链表长度时,会进入死循环。
这种题目是不是默认是没有环的鸭
为什么我运行if(p -> next)会错呢
xd我也遇到了这个问题,我认为是因为要考虑二者没有相交的情况,这个时候返回要让两个指针都指向尾部的null,要是写成(p->next)会发现自始至终指针没有指向尾部的NULL
有道理诶!
第二个方法有问题,如果两个链表没有公共节点,会无限循环
没有公共节点,也会同时走到对方的NULL而相等的
第二个方法没有问题
考研题学学还是很妙的鸭
写的很棒!一看就懂啦!
tql
第二个方法66666666666666
确实666咋想的
考研题
妙!
tql
牛b就完事了
好思路
太妙了
tql
tql
牛逼