博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Leetcode】102. 二叉树的层次遍历
阅读量:6495 次
发布时间:2019-06-24

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

题目

给定一个二叉树,返回其按层次遍历的节点值。 (即逐层地,从左到右访问所有节点)。

例如:

给定二叉树: [3,9,20,null,null,15,7],

3   / \  9  20    /  \   15   7

返回其层次遍历结果:

[  [3],  [9,20],  [15,7]]

题解

我们数据结构的书上教的层序遍历,就是利用一个队列,不断的把左子树和右子树入队。但是这个题目还要要求按照层输出。所以关键的问题是: 如何确定是在同一层的

我们很自然的想到:
如果在入队之前,把上一层所有的节点出队,那么出队的这些节点就是上一层的列表。
由于队列是先进先出的数据结构,所以这个列表是从左到右的。

/** * Definition for a binary tree node. * public class TreeNode { *     int val; *     TreeNode left; *     TreeNode right; *     TreeNode(int x) { val = x; } * } */class Solution {    public List
> levelOrder(TreeNode root) { List
> res = new LinkedList<>(); if (root == null) { return res; } LinkedList
queue = new LinkedList<>(); queue.add(root); while (!queue.isEmpty()) { int size = queue.size(); List
currentRes = new LinkedList<>(); // 当前队列的大小就是上一层的节点个数, 依次出队 while (size > 0) { TreeNode current = queue.poll(); if (current == null) { continue; } currentRes.add(current.val); // 左子树和右子树入队. if (current.left != null) { queue.add(current.left); } if (current.right != null) { queue.add(current.right); } size--; } res.add(currentRes); } return res; }}

这道题可不可以用非递归来解呢?

递归的子问题:遍历当前节点, 对于当前层, 遍历左子树的下一层层,遍历右子树的下一层

递归结束条件: 当前层,当前子树节点是null

/** * Definition for a binary tree node. * public class TreeNode { *     int val; *     TreeNode left; *     TreeNode right; *     TreeNode(int x) { val = x; } * } */class Solution {    public List
> levelOrder(TreeNode root) { List
> res = new LinkedList<>(); if (root == null) { return res; } levelOrderHelper(res, root, 0); return res; } /** * @param depth 二叉树的深度 */ private void levelOrderHelper(List
> res, TreeNode root, int depth) { if (root == null) { return; } if (res.size() <= depth) { // 当前层的第一个节点,需要new 一个list来存当前层. res.add(new LinkedList<>()); } // depth 层,把当前节点加入 res.get(depth).add(root.val); // 递归的遍历下一层. levelOrderHelper(res, root.left, depth + 1); levelOrderHelper(res, root.right, depth + 1); }}

热门阅读

Leetcode名企之路

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

你可能感兴趣的文章
MySQL--------基于binlog实现闪回最佳实战
查看>>
01-查询Oracle中所有用户信息
查看>>
每次打开Microsoft office word2010时都要显示安装配置文件的问题
查看>>
Windows 2008(X64)安装32位SQL2005的ASP.NET注册警告解决方法
查看>>
树讲解(3)——联合权值
查看>>
BigDecimal
查看>>
use the purchases page to try again
查看>>
批处理用WINRAR只压缩某类型的文件
查看>>
我的友情链接
查看>>
Linux上vim编辑器快速入门
查看>>
手工kill病毒小方法--转自51CTO论坛
查看>>
Selenium代码示例
查看>>
memcached性能测试
查看>>
Chrome扩展入门开发
查看>>
[转]Android 之 Window、WindowManager 与窗口管理
查看>>
类加载器复习
查看>>
进程之multiprocessing模块代码篇
查看>>
android XMLPullParser读取xml文件
查看>>
硬件处理和软件处理之间的异同与边界
查看>>
ubantu apt-get源
查看>>