文章507
标签266
分类65

算法:两个链表的第一个公共结点


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

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

输入两个链表,找出它们的第一个公共结点。

(注意因为传入数据是链表,所以错误测试数据的提示是用其他方式显示的,保证传入数据是正确的)


分析

设定两个指针分别从list1和list2开始.

list1当到达链表1结尾时, 继续从链表2开始; list2同理;

最后:

  • 长度相同时

    • 有公共结点,第一次就遍历到;
    • 没有公共结点,走到尾部NULL相遇,返回NULL
  • 长度不同时

    • 有公共结点,第一遍差值就出来了,第二遍一起到公共结点
    • 没有公共,一起到结尾NULL

代码

public class Solution {
    public ListNode FindFirstCommonNode(ListNode head1, ListNode head2) {
        ListNode list1 = head1, list2 = head2;
        while (list1 != list2) {
            list1 = list1 == null ? head2 : list1.next;
            list2 = list2 == null ? head1 : list2.next;
        }
        return list1;
    }
}

本文作者:Jasonkay
本文链接:https://jasonkayzk.github.io/1996/07/27/算法-两个链表的第一个公共结点/
版权声明:本文采用 CC BY-NC-SA 3.0 CN 协议进行许可