聊聊二叉树的前序遍历算法

二叉树顾名思义,一个根节点只会有两个分叉对应,下图所示:

前序遍历先去拿它的左节点,拿完之后再去拿它左节点相邻的右节点,如数据结构是这样

第一中不考虑性能的方式的话,可以使用递归的方式去给他遍历

javascript 复制代码
 function deepTree(data) {
        let arrayData = []
        let fun = (node) => {
            if (node) {
                arrayData.push(node.val)
                //遍历一下左子树
                fun(node.left)
                //遍历一下右子树
                fun(node.right)
            }

            fun(data)
            return arrayData
        }
    }
    deepTree(tree)

依次拿到值的 val;

第二种方式使用栈的形式遍历

javascript 复制代码
  function preorderTraversal(root) {
        if (!root) return []

        let array = []
        let stack = [root]

        while (stack.length) {
            // 出栈
            let o = stack.pop()
            array.push(o.val)

            o.right && stack.push(o.right)
            o.left && stack.push(o.left)
            // console.log('oooo', o);
        }
        console.log(array);
    }
    preorderTraversal(tree)

考虑性能的算法使用 栈形式遍历;

时小记,终有成。

相关推荐
roman_日积跬步-终至千里2 小时前
【模式识别与机器学习(14)】K-means算法中K值确定教程
算法·机器学习·kmeans
测试-鹏哥2 小时前
ITP平台全新Mock服务上线 —— 助力高效API测试
前端·python·测试工具
BlackWolfSky2 小时前
ES6 教程学习笔记
前端·javascript·es6
IT_陈寒2 小时前
Redis性能翻倍的5个冷门技巧:从缓存穿透到集群优化实战指南
前端·人工智能·后端
木易 士心2 小时前
Node.js 性能诊断利器 Clinic.js:原理剖析与实战指南
开发语言·javascript·node.js
不会写DN2 小时前
如何实现UniApp登录拦截?
前端·javascript·vue.js·typescript·uni-app·vue
一只乔哇噻2 小时前
java后端工程师+AI大模型进修ing(研一版‖day59)
java·开发语言·算法·语言模型
不老刘2 小时前
深入理解 React Native 的 Metro
javascript·react native·react.js·metro
哆啦A梦15882 小时前
67 token 过期时间
前端·javascript·vue.js·node.js
天赐学c语言2 小时前
12.2 - LRU缓存 && C语言内存布局
c++·算法·lru·内存布局