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

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

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

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

解题思路:

使用两个指针N1,N2,一个从链表1的头节点开始遍历,我们记为N1,一个从链表2的头节点开始遍历,我们记为N2。

让N1和N2一起遍历,当N1先走完链表1的尽头(为null)的时候,则从链表2的头节点继续遍历,同样,如果N2先走完了链表2的尽头,则从链表1的头节点继续遍历,也就是说,N1和N2都会遍历链表1和链表2。

因为两个指针,同样的速度,走完同样长度(链表1+链表2),不管两条链表有无相同节点,都能够到达同时到达终点。

(N1最后肯定能到达链表2的终点,N2肯定能到达链表1的终点)。

所以,如何得到公共节点:

  • 有公共节点的时候,N1和N2必会相遇,因为长度一样嘛,速度也一定,必会走到相同的地方的,所以当两者相等的时候,则会第一个公共的节点
  • 无公共节点的时候,此时N1和N2则都会走到终点,那么他们此时都是null,所以也算是相等了。

下面看个动态图,可以更形象的表示这个过程~

36

代码:

public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {
        ListNode l1 = pHead1, l2 = pHead2;
        while(l1 != l2){
            l1 = (l1==null)?pHead2:l1.next;
            l2 = (l2==null)?pHead1:l2.next;
        }
        return l1;
    }

复杂度分析:

时间复杂度:O(m+n)。链表1和链表2的长度之和。

空间复杂度:O(1)。常数的空间。

剑指offer 文章被收录于专栏

为刷过的每一道题都书写一篇题解,便于重复练习~

全部评论
如果公共部分的结尾和pHead1的头节点的值一样不就错误了吗?
1 回复 分享
发布于 2022-04-18 09:48
如果不存在焦点不是死循环吗
8 回复 分享
发布于 2022-03-12 21:55
动态图好棒哦
8 回复 分享
发布于 2021-10-04 16:22
真的牛! 两个指针,他们的路程是一样的都是链表一和链表二的长度之和。如果两个链表长度不同,那就相当于是圆圈追及问题,如果两个链表长度一样,那就是指针速度一样,一次遍历就能相遇,就是公共节点。 太牛了,这个想法。根本想不到!
4 回复 分享
发布于 2022-05-29 10:43
厉害,代码这么短啊,比我的那个还短
3 回复 分享
发布于 2022-10-29 14:27 湖北
让我想到两个人用不同的速度跑操场
3 回复 分享
发布于 2021-11-01 15:53
优秀优秀,豁然开朗
2 回复 分享
发布于 2021-12-30 17:35
好绝的想法,我一辈子都到达不到的高度
1 回复 分享
发布于 2024-02-05 14:47 湖南
写的真好!思路妙,编程也妙
1 回复 分享
发布于 2023-08-25 14:50 北京
1 回复 分享
发布于 2022-08-06 18:39
newbee
点赞 回复 分享
发布于 04-14 11:33 四川
这想法,真牛
点赞 回复 分享
发布于 2024-11-07 10:52 广东
点赞 回复 分享
发布于 2024-10-23 16:45 湖北
比官方解析好得多
点赞 回复 分享
发布于 2024-07-05 11:21 湖南
厉害,思路很好,学习
点赞 回复 分享
发布于 2024-03-27 11:27 四川
谢谢,有种豁然开朗的感觉
点赞 回复 分享
发布于 2024-03-24 20:37 贵州
这时间复杂度不是O(m+n)啊,是O((abs(m-n)+1)*min(m,n))
点赞 回复 分享
发布于 2023-11-22 16:18 澳大利亚
好简洁
点赞 回复 分享
发布于 2023-10-18 16:20 广东
好简洁
点赞 回复 分享
发布于 2023-10-18 16:20 广东
真的太妙了,看到动图之后更觉得厉害了!
点赞 回复 分享
发布于 2023-10-10 20:43 江西

相关推荐

不愿透露姓名的神秘牛友
07-02 17:58
点赞 评论 收藏
分享
06-15 18:44
黄淮学院 Java
Lynn012:如果是居民楼还是算了吧,看着有点野呢
点赞 评论 收藏
分享
每晚夜里独自颤抖:这个在牛客不是老熟人了吗
点赞 评论 收藏
分享
07-02 13:50
闽江学院 Java
点赞 评论 收藏
分享
评论
537
71
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务