博客
关于我
[leetcode]102. Binary Tree Level Order Traversal
阅读量:540 次
发布时间:2019-03-09

本文共 1317 字,大约阅读时间需要 4 分钟。

要解决这个问题,我们需要对二叉树进行层序遍历。层序遍历是指从树的根节点开始,逐层从左到右访问所有节点,直到遍历完所有节点。常用方法是广度优先搜索(BFS),使用队列来辅助实现。

方法思路

  • 检查根节点:如果根节点为空,直接返回一个空的结果列表。
  • 初始化队列:将根节点加入队列。
  • 处理队列:在每次循环中,记录当前队列的大小(表示当前处理的层有多少个节点)。然后,遍历这个数量的节点,每个节点取出队列,记录其值,接着将其左孩子和右孩子加入队列(如果不为空)。
  • 记录层序:每次处理完一层节点后,将该层的节点值添加到结果列表中。
  • 解决代码

    import java.util.ArrayList;import java.util.List;import java.util.Queue;import java.util.LinkedList;public class Solution {    public List
    > levelOrder(TreeNode root) { List
    > result = new ArrayList<>(); Queue
    queue = new LinkedList<>(); if (root == null) { return result; } queue.offer(root); while (!queue.isEmpty()) { int num = queue.size(); List
    level = new ArrayList<>(); for (int i = 0; i < num; i++) { TreeNode current = queue.poll(); level.add(current.value); if (current.left != null) { queue.offer(current.left); } if (current.right != null) { queue.offer(current.right); } } result.add(level); } return result; }}

    代码解释

  • 初始化结果列表:使用 ArrayList 来存储每一层的节点值。
  • 队列初始化:使用 LinkedList 作为队列,用于广度优先遍历。
  • 根节点检查:如果根节点为空,直接返回空列表。
  • 队列填充:将根节点加入队列。
  • 处理循环:在每次循环中,记录当前队列的大小 num,表示当前层的节点数。
  • 处理每个节点:取出队列中的节点,记录其值。将其左孩子和右孩子(不为空时)加入队列。
  • 记录层序:将当前层的节点值添加到结果列表中。
  • 返回结果:当队列处理完毕后,返回结果列表。
  • 这种方法确保了每一层的节点按顺序被访问和记录,得到的结果符合层序遍历的要求。

    转载地址:http://wehiz.baihongyu.com/

    你可能感兴趣的文章
    Oracle 常用命令
    查看>>
    Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
    查看>>
    Oracle 权限(grant、revoke)
    查看>>
    oracle 查询clob
    查看>>
    Oracle 比较 B-tree 和 Bitmap 索引
    查看>>
    UML- 组件图(构件图)
    查看>>
    oracle 监听器的工作原理
    查看>>
    oracle 行转列
    查看>>
    Oracle 表
    查看>>
    oracle 课堂笔记
    查看>>
    Oracle 返回结果集的 存储过程
    查看>>
    Oracle 递归
    查看>>
    Oracle 递归函数与拼接
    查看>>
    oracle 逻辑优化,提升高度,综合SQL上下文进行逻辑优化
    查看>>
    oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
    查看>>
    oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
    查看>>
    oracle--用户,权限,角色的管理
    查看>>
    Oracle-定时任务-JOB
    查看>>
    oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>