leetcode 数据结构之 树的层序遍历

简单易懂,让我们来浅谈一下如何对树进行层序遍历吧

哈喽哈喽,我是你们的金樽清酒。树这个结构呀,在计算机领域是十分重要的。基本很多结构,都是树型结构。比如在前端领域,在浏览器通过http协议拿到html文件的时候不就是解析dom树嘛。那我们要解析一棵树,其实就是要遍历它,按照我们需要的顺序将树展开。

题目

给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

示例 1:

ini 复制代码
输入: root = [3,9,20,null,null,15,7]
输出: [[3],[9,20],[15,7]]

示例 2:

lua 复制代码
输入: root = [1]
输出: [[1]]

示例 3:

ini 复制代码
输入: root = []
输出: []

分析

树的层序遍历,是要我们将一棵树一层层的按顺序存进数组。其中用的最多的思路就是用队列的思想。因为队列是先进先出嘛。我们按照顺序,从头到顶,从左到右的先存进队列,那么自然出来的也是从头到顶,从左到右。但是要一层一层的保存,那我们就要进行一些操作了,那就一层一层处理呗。先把前面的出队,然后看它的左右是否有节点,再入队,循环处理。这样就可以一层层的进行操作了。

代码

js 复制代码
function levelOrder(root: TreeNode | null): number[][] {

//二叉树的层序遍历,思想是什么呢?那就是用队列的思想。

if (!root) return []

let result = []

let stack = []

stack.push(root)

while (stack.length > 0) {

result.push([])

const len = stack.length

for (let i = 0; i < len; i++) {

const node = stack.shift()

result[result.length - 1].push(node.val)

if (node.left) {

stack.push(node.left)

}

if (node.right) {

stack.push(node.right)

}

}

}

return result

};

对不起友友们,复制过来不会格式化。有需要可以自行复制格式化。希望对你有所帮助。

相关推荐
你撅嘴真丑17 分钟前
求10000 以内的阶乘 与 字符串最大跨距
数据结构·c++·算法
Figo_Cheung18 分钟前
Figo几何基础论:基于集合几何化的统一理论框架与哲学意涵——首次提出“几何化诱导的全息原理”
算法·机器学习·概率论·迭代加深
CHU72903520 分钟前
智慧陪伴新选择:陪诊陪护预约小程序的暖心功能解析
java·前端·小程序·php
奔跑的web.24 分钟前
TypeScript namespace 详解:语法用法与使用建议
开发语言·前端·javascript·vue.js·typescript
小y要自律28 分钟前
11 string容器 - 子串获取
c++·算法·stl
t1987512828 分钟前
三相计量芯片RN8302B驱动校正程序设计与实现
算法
你怎么知道我是队长30 分钟前
win11系统查看设备配置
android·java·javascript
倾国倾城的反派修仙者31 分钟前
鸿蒙开发——使用弹窗授权保存媒体库资源
开发语言·前端·华为·harmonyos
期末考复习中,蓝桥杯都没时间学了32 分钟前
力扣刷题9
算法·leetcode·职场和发展
砚边数影37 分钟前
线性回归原理(二):梯度下降算法,Java实现单变量/多变量拟合
java·数据库·算法·线性回归·kingbase·kingbasees·金仓数据库