剑指Offer(牛客网) 两个链表的第一个公共结点

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指Offer(牛客网) 两个链表的第一个公共结点相关的知识,希望对你有一定的参考价值。


链接:https://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?tpId=13&tqId=11189&rp=1&ru=%2Fta%2Fcoding-interviews&qru=%2Fta%2Fcoding-interviews%2Fquestion-ranking&tPage=2
来源:牛客网
题目描述
输入两个链表,找出它们的第一个公共结点。(注意因为传入数据是链表,所以错误测试数据的提示是用其他方式显示的,保证传入数据是正确的)

思路:
双指针法。创建两个指针p1和p2,分别指向两个链表的头结点,然后依次往后遍历。如果某个指针到达末尾,则将该指针指向另一个链表的头结点;如果两个指针所指的节点相同,则循环结束,返回当前指针指向的节点。比如两个链表分别为:1->3->4->5->6和2->7->8->9->5->6。短链表的指针p1会先到达尾部,然后重新指向长链表头部,当长链表的指针p2到达尾部时,重新指向短链表头部,此时p1在长链表中已经多走了k步(k为两个链表的长度差值),p1和p2位于同一起跑线,往后遍历找到相同节点即可。其实该方法主要就是用链表循环的方式替代了长链表指针先走k步这一步骤。

/*
public class ListNode
int val;
ListNode next = null;

ListNode(int val)
this.val = val;

*/
public class Solution
public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2)
ListNode h1 = pHead1;
ListNode h2 = pHead2;
while(h1!=h2)
h1=(h1==null)?pHead2:h1.next;
h2=(h2==null)?pHead1:h2.next;

return h1;


以上是关于剑指Offer(牛客网) 两个链表的第一个公共结点的主要内容,如果未能解决你的问题,请参考以下文章

剑指Offer(牛客网) 合并两个排序的链表

剑指Offer(牛客网) 反转链表

手机牛客在线编程入口在哪

剑指 Offer 52. 两个链表的第一个公共节点

剑指offer两个链表的第一个公共结点

[8月4日]剑指 Offer 52. 两个链表的第一个公共节点