博客
关于我
[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/

    你可能感兴趣的文章
    php实现下载文件方法
    查看>>
    php实现单链表
    查看>>
    php实现图片背景换色功能
    查看>>
    php实现多个一维数组对应合并成二维数组
    查看>>
    php实现多关键字查找方法
    查看>>
    PHP实现微信公众号H5支付
    查看>>
    PHP实现微信公众号网页授权
    查看>>
    PHP实现微信小程序推送消息至公众号
    查看>>
    rabbitmq逻辑与开发
    查看>>
    php实现根据身份证获取年龄
    查看>>
    PHP实现的MongoDB数据增删改查
    查看>>
    PHP实现的SSO单点登录系统,拿走就用吧
    查看>>
    php实现短信验证功能
    查看>>
    RabbitMQ连接报错(1)—— None of the specified endpoints were reachable
    查看>>
    php实现逆转数组
    查看>>
    PHP实现通过geoip获取IP地理信息
    查看>>
    PHP实现页面静态化、纯静态化及伪静态化
    查看>>
    php容许ajax跨域,PHP设置允许ajax跨域请求的两种常见方法
    查看>>
    RabbitMQ进程结构分析与性能调优
    查看>>
    PHP对接百度地图
    查看>>