js算法——实现反转链表

简介: js算法——实现反转链表


题目来自leetcode

定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。

输入: 1->2->3->4->5->NULL

输出: 5->4->3->2->1->NULL

/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */
/**
 * @param {ListNode} head
 * @return {ListNode}
 */
var reverseList = function(head) {
};


首先考链表,我们要对链表解构以及栈堆内存十分清晰。

我们要知道我们对链表进行遍历是必然的,所以可以写出

var reverseList = function(head) {
    let curr = head;
    while (curr) {
       //进入下一个循环
       curr=curr.next
    }
};

当我们当头部开始时,头部成了尾部,应该指向null,所以我们应该创建一个null节点,所以第一次遍历时,是头部指向一个null。

但是当我们修改了当前节点的next之后,链表被切断,我们就不能用它进行遍历了,所以我们得要保存被切断之后的链表,声明一个next指针保存

var reverseList = function(head) {
    let res = null
    let curr = head;
    while (curr) {
       const next=curr.next
       curr.next=res
       //进入下一个循环我们要思考一个问题...
       curr=curr.next
    }
};

image.png

上述代码说了进入下一个循环前我们要思考一个问题。

当我们遍历到第二步时,我们希望的是curr能够指向1那个节点,可是没有栈内存也就是没有指针指向它,因此我们要在遍历到下一步时,可以用res指向它。

var reverseList = function(head) {
    let res = null
    let curr = head
    while (curr) {
       const next=curr.next 
       curr.next=res
       //进入下一个循环前该做的事,对应图中步骤1,然后开始循环
       res=curr
       curr=next
    }
};

image.png

res就会指向反转链表的头部,返回即可

var reverseList = function(head) {
    let res = null
    let curr = head
    while (curr) {
       const next=curr.next 
       curr.next=res
       res=curr
       curr=next
    }
    return res
};

提升


k个一组反转?


将反转定义一个方法。

在头部声明一个dummy指向head,作为第一组需要反转的链表的头部,并额外声明两个指针pre和end。

用end.next作为循环结束的条件。

将end移动k个链,若在移动中变为空说明已经没有可以旋转的k个链了,跳出循环。

将end.next置为空,意思就是让原链表从end处截断,但是在反转链表中我们已经学过了,我们应该声明一个next把end后面的链表保存,不然后面内容就丢失了。

用start指向pre.next,用于反转,因为end在k个链处被截断了,所以刚好反转k个。然后用pre接收,也就是把反转的内容连在dummy后面,反转完,start指向的位置是dummy链的尾部,我们只需要让start.next指向原来保存的next,也就是start作为新一组要反转的链表的头部,将pre和end指向它进入循环。

var reverseKGroup = function(head, k) {
   //解释1
   const rev=(start)=>{
     let res=null
     while(start!==null){
         const next=start.next
         start.next=res
         res=start
         start=next
     }
     return res
   }
   //解释2
   const dummy=new ListNode(0,head)
   let pre=dummy,end=dummy
   //解释3
   while(end.next!==null){
      //解释4
      for(let i=0;i<k&&end!==null;i++) end=end.next
      if(end===null) break
      //解释5
      const next=end.next
      end.next=null
      //解释6
      let start=pre.next
      pre.next=rev(start)
      start.next=next
      pre=start
      end=start
   }
   return dummy.next
};


相关文章
|
2月前
|
存储 监控 算法
局域网监控其他电脑的设备信息管理 Node.js 跳表算法
跳表通过分层索引实现O(logn)的高效查询、插入与删除,适配局域网监控中设备动态接入、IP映射及范围筛选等需求,相比传统结构更高效稳定,适用于Node.js环境下的实时设备管理。
116 9
|
4月前
|
存储 监控 JavaScript
基于布隆过滤器的 Node.js 算法在局域网电脑桌面监控设备快速校验中的应用研究
本文探讨了布隆过滤器在局域网电脑桌面监控中的应用,分析其高效空间利用率、快速查询性能及动态扩容优势,并设计了基于MAC地址的校验模型,提供Node.js实现代码,适用于设备准入控制与重复数据过滤场景。
198 0
|
2月前
|
存储 监控 JavaScript
企业上网监控系统的恶意 URL 过滤 Node.js 布隆过滤器算法
布隆过滤器以低内存、高效率特性,解决企业上网监控系统对百万级恶意URL实时检测与动态更新的难题,通过概率性判断实现毫秒级过滤,内存占用降低96%,适配大规模场景需求。
232 3
|
2月前
|
存储 监控 算法
电脑管控软件的进程优先级调度:Node.js 红黑树算法
红黑树凭借O(log n)高效插入、删除与查询特性,适配电脑管控软件对进程优先级动态调度的高并发需求。其自平衡机制保障系统稳定,低内存占用满足轻量化部署,显著优于传统数组或链表方案,是实现关键进程资源优先分配的理想选择。
145 1
|
3月前
|
运维 监控 JavaScript
基于 Node.js 图结构的局域网设备拓扑分析算法在局域网内监控软件中的应用研究
本文探讨图结构在局域网监控系统中的应用,通过Node.js实现设备拓扑建模、路径分析与故障定位,提升网络可视化、可追溯性与运维效率,结合模拟实验验证其高效性与准确性。
236 3
|
7月前
|
监控 算法 JavaScript
基于 JavaScript 图算法的局域网网络访问控制模型构建及局域网禁止上网软件的技术实现路径研究
本文探讨局域网网络访问控制软件的技术框架,将其核心功能映射为图论模型,通过节点与边表示终端设备及访问关系。以JavaScript实现DFS算法,模拟访问权限判断,优化动态策略更新与多层级访问控制。结合流量监控数据,提升网络安全响应能力,为企业自主研发提供理论支持,推动智能化演进,助力数字化管理。
191 4
|
7月前
|
监控 算法 JavaScript
公司局域网管理视域下 Node.js 图算法的深度应用研究:拓扑结构建模与流量优化策略探析
本文探讨了图论算法在公司局域网管理中的应用,针对设备互联复杂、流量调度低效及安全监控困难等问题,提出基于图论的解决方案。通过节点与边建模局域网拓扑结构,利用DFS/BFS实现设备快速发现,Dijkstra算法优化流量路径,社区检测算法识别安全风险。结合WorkWin软件实例,展示了算法在设备管理、流量调度与安全监控中的价值,为智能化局域网管理提供了理论与实践指导。
186 3
|
7月前
|
存储 监控 算法
公司内部网络监控中的二叉搜索树算法:基于 Node.js 的实时设备状态管理
在数字化办公生态系统中,公司内部网络监控已成为企业信息安全管理体系的核心构成要素。随着局域网内终端设备数量呈指数级增长,实现设备状态的实时追踪与异常节点的快速定位,已成为亟待解决的关键技术难题。传统线性数据结构在处理动态更新的设备信息时,存在检索效率低下的固有缺陷;而树形数据结构因其天然的分层特性与高效的检索机制,逐渐成为网络监控领域的研究热点。本文以二叉搜索树(Binary Search Tree, BST)作为研究对象,系统探讨其在公司内部网络监控场景中的应用机制,并基于 Node.js 平台构建一套具备实时更新与快速查询功能的设备状态管理算法框架。
264 3
|
2月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
214 0
|
2月前
|
数据采集 分布式计算 并行计算
mRMR算法实现特征选择-MATLAB
mRMR算法实现特征选择-MATLAB
169 2

热门文章

最新文章