JS算法-链表相交

简介: JS算法-链表相交

题目


你两个单链表的头节点 headAheadB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null

输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,6,1,8,4,5], skipA = 2, skipB = 3
输出:Intersected at '8'
解释:相交节点的值为 8 (注意,如果两个链表相交则不能为 0)。


题解


第一种


首先我们在函数中先初始化变量 lenA, lenB, a, b 分别为 0, 0, headA, headB,然后通过 while 循环遍历链表 A 和 B,计算它们的长度 lenA 和 lenB,并记录最后一个节点 a 和 b, 如果 a !== b,说明它们没有交点,直接返回 null,如果 lenA > lenB,说明链表 A 比链表 B 长,交换它们的位置,使得 lenA <= lenB,接下来初始化变量 count = lenB - lenA,表示链表 B 需要向后移动的步数,在通过 while 循环将链表 B 向后移动 count 步,同时遍历链表 A 和 B,直到找到第一个相同的节点,即为它们的交点,最后返回交点或 null

var getIntersectionNode = function (headA, headB) {
  let lenA = 0;
  let lenB = 0;
  let a = headA;
  let b = headB;
  while (a.next) {
    lenA++;
    a = a.next;
  }
  while (b.next) {
    lenB++;
    b = b.next;
  }
  if (a !== b) return null;
  if (lenA > lenB) {
    [headA, headB] = [headB, headA];
    [lenA, lenB] = [lenB, lenA];
  }
  let count = lenB - lenA;
  while (count--) {
    headB = headB.next;
  }
  while (headB && headA) {
    if (headB === headA) return headA;
    headB = headB.next;
    headA = headA.next;
  }
  return null;
};


第二种


首先定义两个指针p1和p2,分别指向两个链表的头节点,然后在while循环中,判断p1和p2是否相等。如果相等,说明已经找到了两个链表的交点,直接返回p1即可,如果p1或p2为null,说明已经到达了链表的末尾,需要将它们重新指向另一个链表的头节点,继续遍历。如果p1为null,就将它指向headB;如果p2为null,就将它指向headA,最后,如果两个链表有交点,while循环结束后p1就指向了交点。如果两个链表没有交点,while循环结束后p1和p2都为null,直接返回其中一个即可

var getIntersectionNode = function (headA, headB) {
  let p1 = headA, p2 = headB;
  while (p1 != p2) {
    if (p1 == null) {
      p1 = headB
    } else {
      p1 = p1.next
    }
    if (p2 == null) {
      p2 = headA
    } else {
      p2 = p2.next
    }
  }
  return p1
};
相关文章
|
4月前
|
存储 监控 算法
局域网监控其他电脑的设备信息管理 Node.js 跳表算法
跳表通过分层索引实现O(logn)的高效查询、插入与删除,适配局域网监控中设备动态接入、IP映射及范围筛选等需求,相比传统结构更高效稳定,适用于Node.js环境下的实时设备管理。
176 9
|
6月前
|
存储 监控 JavaScript
基于布隆过滤器的 Node.js 算法在局域网电脑桌面监控设备快速校验中的应用研究
本文探讨了布隆过滤器在局域网电脑桌面监控中的应用,分析其高效空间利用率、快速查询性能及动态扩容优势,并设计了基于MAC地址的校验模型,提供Node.js实现代码,适用于设备准入控制与重复数据过滤场景。
260 0
|
4月前
|
存储 监控 JavaScript
企业上网监控系统的恶意 URL 过滤 Node.js 布隆过滤器算法
布隆过滤器以低内存、高效率特性,解决企业上网监控系统对百万级恶意URL实时检测与动态更新的难题,通过概率性判断实现毫秒级过滤,内存占用降低96%,适配大规模场景需求。
319 3
|
4月前
|
存储 监控 算法
电脑管控软件的进程优先级调度:Node.js 红黑树算法
红黑树凭借O(log n)高效插入、删除与查询特性,适配电脑管控软件对进程优先级动态调度的高并发需求。其自平衡机制保障系统稳定,低内存占用满足轻量化部署,显著优于传统数组或链表方案,是实现关键进程资源优先分配的理想选择。
261 1
|
5月前
|
运维 监控 JavaScript
基于 Node.js 图结构的局域网设备拓扑分析算法在局域网内监控软件中的应用研究
本文探讨图结构在局域网监控系统中的应用,通过Node.js实现设备拓扑建模、路径分析与故障定位,提升网络可视化、可追溯性与运维效率,结合模拟实验验证其高效性与准确性。
332 3
|
8月前
|
机器学习/深度学习 算法
24. 两两交换链表中的节点, 19.删除链表的倒数第N个节点 ,面试题 02.07. 链表相交
1. **两两交换链表中的节点**:通过引入虚拟头结点,使所有节点都能采用统一的交换逻辑,避免对头结点单独处理。 2. **删除链表的倒数第N个节点**:利用双指针技巧,让快慢指针保持N个节点的距离,当快指针到达末尾时,慢指针正好指向待删除节点的前一个节点。 3. **链表相交**:先计算两链表长度并调整起点,确保从相同距离末尾的位置开始遍历,从而高效找到相交节点或确定无交点。 以上方法均在时间复杂度和空间复杂度上进行了优化,适合用于理解和掌握链表的基本操作及常见算法设计思路。
|
9月前
|
监控 算法 JavaScript
基于 JavaScript 图算法的局域网网络访问控制模型构建及局域网禁止上网软件的技术实现路径研究
本文探讨局域网网络访问控制软件的技术框架,将其核心功能映射为图论模型,通过节点与边表示终端设备及访问关系。以JavaScript实现DFS算法,模拟访问权限判断,优化动态策略更新与多层级访问控制。结合流量监控数据,提升网络安全响应能力,为企业自主研发提供理论支持,推动智能化演进,助力数字化管理。
227 4
|
9月前
|
监控 算法 JavaScript
公司局域网管理视域下 Node.js 图算法的深度应用研究:拓扑结构建模与流量优化策略探析
本文探讨了图论算法在公司局域网管理中的应用,针对设备互联复杂、流量调度低效及安全监控困难等问题,提出基于图论的解决方案。通过节点与边建模局域网拓扑结构,利用DFS/BFS实现设备快速发现,Dijkstra算法优化流量路径,社区检测算法识别安全风险。结合WorkWin软件实例,展示了算法在设备管理、流量调度与安全监控中的价值,为智能化局域网管理提供了理论与实践指导。
239 3
|
4月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
463 0
|
4月前
|
数据采集 分布式计算 并行计算
mRMR算法实现特征选择-MATLAB
mRMR算法实现特征选择-MATLAB
314 2