当前位置: 首页 > article >正文

js.二叉树的层序遍历2

链接:107. 二叉树的层序遍历 II - 力扣(LeetCode)

题目:

给你二叉树的根节点 root ,返回其节点值 自底向上的层序遍历 。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)

示例 1:

输入:root = [3,9,20,null,null,15,7]
输出:[[15,7],[9,20],[3]]

示例 2:

输入:root = [1]
输出:[[1]]

示例 3:

输入:root = []
输出:[]

提示:

  • 树中节点数目在范围 [0, 2000] 内
  • -1000 <= Node.val <= 1000

代码:

/**
 * Definition for a binary tree node.
 * function TreeNode(val, left, right) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.left = (left===undefined ? null : left)
 *     this.right = (right===undefined ? null : right)
 * }
 */
/**
 * @param {TreeNode} root
 * @return {number[][]}
 */
var levelOrderBottom = function(root) {
    if(root == null) return []
    //rt代表层次遍历每一层的结点
    let result = [] , rt = [root]
    while(rt.length){
        //用p记录每一层的数据
        let p = [] , n = rt.length
        for(let i = 0 ; i<n ; i++ ){
            p.push(rt[0].val)
            rt[0].left==null?null:rt.push(rt[0].left)
            rt[0].right==null?null:rt.push(rt[0].right)
            rt.shift()
        }
        result.unshift(p)
    }
    return result
};


http://www.kler.cn/a/411815.html

相关文章:

  • 基于Kubernetes编排部署EFK日志收集系统
  • 对比 MyBatis 批处理 BATCH 模式与 INSERT INTO ... SELECT ... UNION ALL 进行批量插入
  • || 与 ??的区别
  • Cocos简介和认知
  • 2025蓝桥杯(单片机)备赛--扩展外设之UART1的原理与应用(十二)
  • VITE+VUE3+TS环境搭建
  • [C++]:IO流
  • JavaWeb后端开发知识储备2
  • 嵌入式QT中UDP通信实现方法
  • 单例模式入门
  • 文件系统的作用
  • C++条件编译指令:#if、#elif、#ifdef、#ifndef、#elifdef、#elifndef、#else、#endif
  • On-Chip-Network之routing
  • [HarmonyOS] 解决HMRouter路由地址无法抽取的问题
  • C#上机练习66-70
  • 网络安全防范
  • 鸿蒙HarmonyOS学习笔记(4)
  • 3D导航案例
  • 钉钉与企业微信机器人:助力网站定时任务高效实现
  • RTMP协议
  • 基于matlab的电力系统潮流计算
  • js中this的指向问题
  • 代码随想录算法训练营第五十八天|Day58 图论
  • JavaScript的运算符与Python的对比
  • leetcode hot100【LeetCode 215.数组中的第K个最大元素】java实现
  • 【AI技术赋能有限元分析应用实践】FEniCS 安装在Ubuntu路径实现python调用