题解 | #两个链表的第一个公共结点#

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

https://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46

/*
struct ListNode {
	int val;
	struct ListNode *next;
	ListNode(int x) :
			val(x), next(NULL) {
	}
};*/
class Solution {
public:
    ListNode* FindFirstCommonNode( ListNode* pHead1, ListNode* pHead2) {
        ListNode *p1 = pHead1, *p2 = pHead2;
		while (p1 != p2) {
			p1 = p1? p1->next: pHead2;
			p2 = p2? p2->next: pHead1;
		}
		return p1;
    }
};

思路:用两个指针分别遍历两个链表,如果遍历到头了就移动到另一个链表的头部再遍历,直到他们相遇。

假设公共部分长度为n,第一个链表非公共部分长度为a,第二个链表为b,则它们走过a + b + n个节点时,一定能在公共部分的头部相遇。

全部评论

相关推荐

点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务