算法1
思路:这个题是小学奥数题吧,代码比较简单,思路有点难,如果是有交叉的,相当于是a+c+b=b+c+a,如果是是平行的情况也一样
C++ 代码
/**
* 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(p!=q){//两指针没有相遇
if(p) p=p->next;//p向后走
else p=headB;//走到没有路,从另一个岔路口走
if(q) q=q->next;//q同理
else q=headA;
}
return p;
}
};