JS算法-二叉树的前序遍历

简介: JS算法-二叉树的前序遍历

题目


给你二叉树的根节点 root ,返回它节点值的 前序 **遍历。

输入: root = [1,null,2,3]
输出: [1,2,3]


题解


第一种


我们先初始化数组 res 为空,将当前节点 root 设为根节点。如果左子树 exist,则在左子树中,找到当前节点 root 的 inorder遍历的前驱节点 t。t是左子树中最右边的节点,它满足t.right == null 或 t.right == root。如果 t.right == null,则将root加入res数组,然后将 t.right 设为 root,将 root 更新为root.left。此时,我们可以认为 t.right 是 root 的后继节点。如果 t.right == root,则说明当前节点的左子树已经遍历完成,将 t.right 设为 null,将 root 更新为 root.right。此时,我们已经遍历完成 root 的左子树和根节点。重复上述步骤,如果左子树不存在,则将 root 的值加入 res 数组,然后将 root 更新为 root.right。此时,我们已经遍历完成root的左、右子树和根节点。重复步骤1。如果 root 为 null,则说明遍历完成,返回 res 数组。

var preorderTraversal = function(root) {
    const res = [];
    while(root) {
        if(root.left) {
            let t = root.left;
            while(t.right && t.right != root) {
                t = t.right; 
            }
            if(!t.right) {
                res.push(root.val);
                t.right = root;
                root = root.left;
            }
            else {
                t.right = null;
                root = root.right;
            }
        }
        else {
            res.push(root.val);
            root = root.right;
        }
    }
    return res;
};


第二种


首先定义了一个空数组 res,用来存放遍历后的结果。如果输入的节点为空,则直接返回结果数组。接下来,定义了一个栈 stack,将根节点压入栈中。然后进行循环操作,从栈中弹出一个节点,并将该节点的值压入结果数组 res 中。如果该节点的右子节点不为空,则将其右子节点压入栈中。如果该节点的左子节点不为空,则将其左子节点压入栈中。循环直到栈为空,最后返回结果数组 res

    var preorderTraversal = function(root) {
      const res = [];
      if(root === null) return res;
      const stack = [];
      stack.push(root);
      while(stack.length > 0){
          const cur = stack.pop();
          res.push(cur.val);
          if(cur.right !== null)
              stack.push(cur.right);
          if(cur.left !== null)
              stack.push(cur.left);
      }
      return res;
  };
相关文章
|
3月前
|
存储 监控 算法
局域网监控其他电脑的设备信息管理 Node.js 跳表算法
跳表通过分层索引实现O(logn)的高效查询、插入与删除,适配局域网监控中设备动态接入、IP映射及范围筛选等需求,相比传统结构更高效稳定,适用于Node.js环境下的实时设备管理。
156 9
|
5月前
|
存储 监控 JavaScript
基于布隆过滤器的 Node.js 算法在局域网电脑桌面监控设备快速校验中的应用研究
本文探讨了布隆过滤器在局域网电脑桌面监控中的应用,分析其高效空间利用率、快速查询性能及动态扩容优势,并设计了基于MAC地址的校验模型,提供Node.js实现代码,适用于设备准入控制与重复数据过滤场景。
234 0
|
3月前
|
存储 监控 JavaScript
企业上网监控系统的恶意 URL 过滤 Node.js 布隆过滤器算法
布隆过滤器以低内存、高效率特性,解决企业上网监控系统对百万级恶意URL实时检测与动态更新的难题,通过概率性判断实现毫秒级过滤,内存占用降低96%,适配大规模场景需求。
278 3
|
3月前
|
存储 监控 算法
电脑管控软件的进程优先级调度:Node.js 红黑树算法
红黑树凭借O(log n)高效插入、删除与查询特性,适配电脑管控软件对进程优先级动态调度的高并发需求。其自平衡机制保障系统稳定,低内存占用满足轻量化部署,显著优于传统数组或链表方案,是实现关键进程资源优先分配的理想选择。
214 1
|
4月前
|
运维 监控 JavaScript
基于 Node.js 图结构的局域网设备拓扑分析算法在局域网内监控软件中的应用研究
本文探讨图结构在局域网监控系统中的应用,通过Node.js实现设备拓扑建模、路径分析与故障定位,提升网络可视化、可追溯性与运维效率,结合模拟实验验证其高效性与准确性。
294 3
|
8月前
|
监控 算法 JavaScript
公司局域网管理视域下 Node.js 图算法的深度应用研究:拓扑结构建模与流量优化策略探析
本文探讨了图论算法在公司局域网管理中的应用,针对设备互联复杂、流量调度低效及安全监控困难等问题,提出基于图论的解决方案。通过节点与边建模局域网拓扑结构,利用DFS/BFS实现设备快速发现,Dijkstra算法优化流量路径,社区检测算法识别安全风险。结合WorkWin软件实例,展示了算法在设备管理、流量调度与安全监控中的价值,为智能化局域网管理提供了理论与实践指导。
222 3
|
8月前
|
存储 监控 算法
公司内部网络监控中的二叉搜索树算法:基于 Node.js 的实时设备状态管理
在数字化办公生态系统中,公司内部网络监控已成为企业信息安全管理体系的核心构成要素。随着局域网内终端设备数量呈指数级增长,实现设备状态的实时追踪与异常节点的快速定位,已成为亟待解决的关键技术难题。传统线性数据结构在处理动态更新的设备信息时,存在检索效率低下的固有缺陷;而树形数据结构因其天然的分层特性与高效的检索机制,逐渐成为网络监控领域的研究热点。本文以二叉搜索树(Binary Search Tree, BST)作为研究对象,系统探讨其在公司内部网络监控场景中的应用机制,并基于 Node.js 平台构建一套具备实时更新与快速查询功能的设备状态管理算法框架。
296 3
|
10月前
|
监控 算法 JavaScript
企业用网络监控软件中的 Node.js 深度优先搜索算法剖析
在数字化办公盛行的当下,企业对网络监控的需求呈显著增长态势。企业级网络监控软件作为维护网络安全、提高办公效率的关键工具,其重要性不言而喻。此类软件需要高效处理复杂的网络拓扑结构与海量网络数据,而算法与数据结构则构成了其核心支撑。本文将深入剖析深度优先搜索(DFS)算法在企业级网络监控软件中的应用,并通过 Node.js 代码示例进行详细阐释。
209 2
|
10月前
|
存储 算法 JavaScript
基于 Node.js 深度优先搜索算法的上网监管软件研究
在数字化时代,网络环境呈现出高度的复杂性与动态性,上网监管软件在维护网络秩序与安全方面的重要性与日俱增。此类软件依托各类数据结构与算法,实现对网络活动的精准监测与高效管理。本文将深度聚焦于深度优先搜索(DFS)算法,并结合 Node.js 编程语言,深入剖析其在上网监管软件中的应用机制与效能。
153 6
|
10月前
|
JavaScript 前端开发 算法
JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码)
Array.sort() 是一个功能强大的方法,通过自定义的比较函数,可以处理各种复杂的排序逻辑。无论是简单的数字排序,还是多字段、嵌套对象、分组排序等高级应用,Array.sort() 都能胜任。同时,通过性能优化技巧(如映射排序)和结合其他数组方法(如 reduce),Array.sort() 可以用来实现高效的数据处理逻辑。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~