两个链表的第一个公共节点使用JavaScript解决算法问题

简介: 两个链表的第一个公共节点使用JavaScript解决算法问题

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


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

如下面的两个链表


image.png


在节点 c1 开始相交。

示例 1:


image.png


输入: intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA = 2, skipB = 3

输出: Reference of the node with value = 8

输入解释: 相交节点的值为 8 (注意,如果两个列表相交则不能为 0)。从各自的表头开始算起,链表 A 为 [4,1,8,4,5],链表 B 为 [5,0,1,8,4,5]。在 A 中,相交节点前有 2 个节点;在 B 中,相交节点前有 3 个节点。

示例 2:


image.png


输入: intersectVal = 2, listA = [0,9,1,2,4], listB = [3,2,4], skipA = 3, skipB = 1

输出: Reference of the node with value = 2

输入解释: 相交节点的值为 2 (注意,如果两个列表相交则不能为 0)。从各自的表头开始算起,链表 A 为 [0,9,1,2,4],链表 B 为 [3,2,4]。在 A 中,相交节点前有 3 个节点;在 B 中,相交节点前有 1 个节点。


解题思路


判断两个链表是否相交,可以使用哈希集合存储链表节点。遍历链表A,进行存储到哈希表内,然后再遍历B列表,判断该节点是否存在于此哈希表中

具体步骤如下:

  • 第一步:初始化一个set哈希集合,用于存储链表节点
  • 第二步:循环存储A链表节点
  • 第三步: 循环判断B链表的节点是否存在于集合内,如果存在则返回当前节点
  • 第四步:走到这就说明两个链表没有相交,所以返回null
var getIntersectionNode = function(headA, headB) {
    let set = new Set()
    let temp = headA
    while(temp){
        set.add(temp)
        temp = temp.next
    }
    temp = headB
    while(temp){
        if(set.has(temp)){
            return temp
        }
        temp = temp.next
    }
    return null
};


image.png


目录
相关文章
|
7天前
|
算法
【优选算法专栏】专题九:链表--------两两交换链表中的节点
【优选算法专栏】专题九:链表--------两两交换链表中的节点
14 0
|
1月前
|
算法
【数据结构与算法】题解 | #反转链表#
【数据结构与算法】题解 | #反转链表#
|
7天前
|
算法
算法系列--递归(一)--与链表有关(上)
算法系列--递归(一)--与链表有关
14 0
|
7天前
|
算法
算法系列--链表刷题(二)(下)
算法系列--链表刷题(二)(下)
11 0
|
1月前
leetcode2487.从链表中移除节点
leetcode2487.从链表中移除节点
20 1
|
1月前
|
算法 Java 索引
[Java·算法·简单] LeetCode 141. 环形链表 详细解读
[Java·算法·简单] LeetCode 141. 环形链表 详细解读
23 0
|
1月前
|
C语言
【C语言】Leetcode 876. 链表的中间节点
【C语言】Leetcode 876. 链表的中间节点
15 0
|
1月前
|
算法
常见算法题—707.设计链表
【2月更文挑战第10天】
34 7
|
1月前
|
存储 算法
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
|
1月前
|
存储 算法 C语言
【数据结构与算法】【约瑟夫问题】还在用递归?教你用链表秒杀约瑟夫
【数据结构与算法】【约瑟夫问题】还在用递归?教你用链表秒杀约瑟夫