首页 > web前端 > js教程 > js中找到两个链表的第一个公共结点的算法

js中找到两个链表的第一个公共结点的算法

不言
发布: 2018-07-23 11:00:14
原创
1547 人浏览过

这篇文章给大家分享的内容是关于js中找到两个链表的第一个公共结点的算法  ,有一定的参考价值,有需要的朋友可以参考一下。

题目描述

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

分析

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

代码实现

/*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;
}
登录后复制

相关推荐:

js中实现滑动窗口的最大值的算法    

js中利用两个栈实现队列的算法

以上是js中找到两个链表的第一个公共结点的算法的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
mac算法 - php实现java的mac hmac_sha1加密算法
来自于 1970-01-01 08:00:00
0
0
0
php的运算方法
来自于 1970-01-01 08:00:00
0
0
0
javascript - 前端面试的一道算法题
来自于 1970-01-01 08:00:00
0
0
0
javascript - 下面的这段算法代码求解释
来自于 1970-01-01 08:00:00
0
0
0
php数组拆分的算法问题
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板