LeetCode/剑指 Offer 52. 两个链表的第一个公共节点
剑指 Offer 52. 两个链表的第一个公共节点
输入两个链表,找出它们的第一个公共节点。
如下面的两个链表:

在节点 c1 开始相交。
示例 1:

1 | 输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA = 2, skipB = 3 |
示例 2:

1 | 输入:intersectVal = 2, listA = [0,9,1,2,4], listB = [3,2,4], skipA = 3, skipB = 1 |
示例 3:

1 | 输入:intersectVal = 0, listA = [2,6,4], listB = [1,5], skipA = 3, skipB = 2 |
注意:
- 如果两个链表没有交点,返回 null.
- 在返回结果后,两个链表仍须保持原有的结构。
- 可假定整个链表结构中没有循环。
- 程序尽量满足 O(n) 时间复杂度,且仅用 O(1) 内存。
来源:力扣(LeetCode)
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题解:
本题是左神讲过的原题,要判断两个链表是否相交,就需要消除两个链表的长度差(如果两链表长度相等可以忽略这一步),具体做法就是定义两个指针分别指向两个链表,如果两个指针所指的当前结点不想等,则向后遍历。如果其中一个指针指向了链表的尾部,这时候另一个指针一定指向的是较长链表,我们把指向空的指针重新指向长链表的头结点(注意这里是指向长链表的头结点,即现在两个指针指向同一个链表),然后再让两个指针一次一步继续向后走,当最开始指向长链表的指针到链表尾部的时候,将它指向短链表的头结点。此刻,两个指针交换了最初指向的链表,而且从此刻开始出发的话,两个指针距离链表尾部的距离是一样的,然后两个指针都向后遍历,如果遇到相等的结点,则证明两个链表相交,如果不相等则不相交。
具体代码如下:
1 | /** |

