AcWing 66 两个链表的第一个公共结点
2019-03-14 10:42
176 查看
题目描述:‘
输入两个链表,找出它们的第一个公共结点。
当不存在公共节点时,返回空节点。
样例
[code]给出两个链表如下所示: A: a1 → a2 ↘ c1 → c2 → c3 ↗ B: b1 → b2 → b3 输出第一个公共节点c1
分析:
本题与AcWing 34 链表中环的入口结点有点类似,不过更为简单。设上图中a1到c1的长度为x,b1到c1的长度为y,c1到c3的长度为z,则令p指向第一个链表头结点,q指向第二个链表头结点,p,q逐渐右移,当p到达链表结尾时,从第二个链表起点开始继续遍历;同样的q到达末尾时从第一个链表头结点开始遍历,于是某时刻p,q必然会相遇于c1点(若有公共结点)。此时p移动的距离为x+z+y,q移动的距离为y+z+x。如果没有公共结点,则二者会相遇于末节点的后一个节点,也就是空节点。
[code]/** * 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; else p = headB; if(q) q = q->next; else q = headA; } return p; } };
相关文章推荐
- 两个链表的第一个公共结点
- 面试题37 两个链表的第一个公共结点
- 剑指offer:两个链表的第一个公共结点输入两个链表,找出它们的第一个公共结点。
- 两个链表的第一个公共结点 java
- 37 两个链表的第一个公共结点
- 题目1505:两个链表的第一个公共结点
- 36两个链表的第一个公共结点
- 输入两个链表,找出它们的第一个公共结点
- 输入两个链表,找出它们的第一个公共结点
- 求两个链表的第一个公共结点各种情况及三种思路分析
- 求两个链表的第一个公共结点各种情况及三种思路分析
- 两个链表的第一个公共结点
- 两个链表的第一个公共结点
- 两个链表的第一个公共结点
- (整理)Java实现链表--找到两个链表的第一个公共结点(网易笔试题2016)
- 找出两个链表的第一个公共结点
- 剑指offer(33)-两个链表的第一个公共结点
- 【面试题037】两个链表的第一个公共结点
- 《剑指offer》刷题笔记(时间空间效率的平衡):两个链表的第一个公共结点
- 两个链表的第一个公共结点