【刷算法】两个链表的第一个公共结点

简介: 【刷算法】两个链表的第一个公共结点

题目描述


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


分析


考虑到两个链表不一样长的情况,算出两个链表的长度差,然后长的链表要先把长度差走完,然后两个链表再一起走。


代码实现


/*function ListNode(x){
    this.val = x;
    this.next = null;
}*/
function FindFirstCommonNode(h1, h2)
{
    var h1Len = 0, h2Len = 0;
    var cur = h1;
    while(cur!==null){
        h1Len++;
        cur = cur.next;
    }
    cur = h2;
    while(cur!==null){
        h2Len++;
        cur = cur.next;
    }
    var distance = 0;
    var t1, t2;
    if(h1Len > h2Len){
        t1 = h1;
        t2 = h2;
        distance = h1Len - h2Len;
    }else{
        t1 = h2;
        t2 = h1;
        distance = h2Len - h1Len;
    }
    while(distance !== 0){
        t1 = t1.next;
        distance--;
    }
    while(t1 !== t2){
        t1 = t1.next;
        t2 = t2.next;
    }
    return t1;
}



相关文章
|
29天前
|
算法
【C算法】链表算法
【C算法】链表算法
|
4天前
链表的中间结点
链表的中间结点
166 57
|
27天前
|
算法
LeetCode第19题删除链表的倒数第 N 个结点
该文章介绍了 LeetCode 第 19 题删除链表的倒数第 N 个结点的解法,通过使用快慢双指针,先将快指针移动 n 步,然后快慢指针一起遍历,直到快指针到达链尾,从而找到倒数第 N 个结点的前一个结点进行删除,同时总结了快慢指针可减少链表遍历次数的特点。
LeetCode第19题删除链表的倒数第 N 个结点
|
28天前
|
算法
【算法】合并两个有序链表(easy)——递归算法
【算法】合并两个有序链表(easy)——递归算法
【算法】合并两个有序链表(easy)——递归算法
|
2月前
【数据结构OJ题】链表中倒数第k个结点
牛客题目——链表中倒数第k个结点
26 1
【数据结构OJ题】链表中倒数第k个结点
|
26天前
|
算法
【数据结构与算法】共享双向链表
【数据结构与算法】共享双向链表
10 0
|
26天前
|
算法
【数据结构与算法】双向链表
【数据结构与算法】双向链表
10 0
|
26天前
|
算法
【数据结构与算法】循环链表
【数据结构与算法】循环链表
10 0
|
26天前
|
存储 算法
【数据结构与算法】链表
【数据结构与算法】链表
15 0
|
28天前
【刷题记录】链表的中间结点
【刷题记录】链表的中间结点