java分层打印二叉树_基于Java的二叉树层序遍历打印实现

java分层打印二叉树_基于Java的二叉树层序遍历打印实现层序遍历的思路:若树为空,则返回空,否则从树的第一层开始,即从根节点,从上而下逐层遍历。1.二叉树层序遍历Ⅰ——剑指offer32-Ⅰ从上到下,从左到右打印二叉树,返回一维数组int[]res。classSolution{publicint[]levelOrder(TreeNoderoot){if(root==null)returnnewint[0];Queueq=…

大家好,又见面了,我是你们的朋友全栈君。

层序遍历的思路:若树为空,则返回空,否则从树的第一层开始,即从根节点,从上而下逐层遍历。

1. 二叉树层序遍历Ⅰ——剑指offer32-Ⅰ

从上到下,从左到右打印二叉树,返回一维数组int[] res。

class Solution {

public int[] levelOrder(TreeNode root) {

if (root == null) return new int[0];

Queue q = new LinkedList<>();

q.add(root);

List list = new ArrayList<>();

while (!q.isEmpty()) {

TreeNode node = q.poll();

list.add(node.val);

if (node.left != null) q.add(node.left);

if (node.right != null) q.add(node.right);

}

int[] res = new int[list.size()];

for (int i = 0; i < res.length; i++)

res[i] = list.get(i);

return res;

}

}

2. 二叉树层序遍历Ⅱ——剑指offer32-Ⅱ/LeetCode102

从上到下,从左到右打印二叉树,返回List> res。

class Solution {

public List> levelOrder(TreeNode root) {

List> res = new ArrayList<>();

Queue q = new LinkedList<>();

if (root != null) q.add(root);

while (!q.isEmpty()) {

List list = new ArrayList<>();

for (int i = q.size(); i > 0; i–) {

TreeNode node = q.poll();

list.add(node.val);

if (node.left != null) q.add(node.left);

if (node.right != null) q.add(node.right);

}

res.add(list);

}

return res;

}

}

3. 二叉树层序遍历Ⅲ——剑指offer32-Ⅲ/LeetCode103

从上到下,按zigzag方式打印(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行),返回List> res。

class Solution {

public List> zigzagLevelOrder(TreeNode root) {

List> res = new ArrayList<>();

Queue q = new LinkedList<>();

if (root != null) q.add(root);

while (!q.isEmpty()) {

LinkedList list = new LinkedList<>();

for (int i = q.size(); i > 0; i–) {

TreeNode node = q.poll();

if (res.size() % 2 == 0) list.addLast(node.val);

else list.addFirst(node.val);

if (node.left != null) q.add(node.left);

if (node.right != null) q.add(node.right);

}

res.add(list);

}

return res;

}

}

4. 二叉树层序遍历Ⅳ——LeetCode107

从下到上,从左到右打印二叉树,返回List> res。

class Solution {

public List> levelOrderBottom(TreeNode root) {

List> res = new ArrayList<>();

Queue q = new LinkedList<>();

if (root != null) q.add(root);

while (!q.isEmpty()) {

List list = new ArrayList<>();

for (int i = q.size(); i > 0; i–) {

TreeNode node = q.poll();

list.add(node.val);

if (node.left != null) q.add(node.left);

if (node.right != null) q.add(node.right);

}

// 头插法

res.add(0, list);

}

return res;

}

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143545.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • C语言魔塔游戏[通俗易懂]

    C语言魔塔游戏[通俗易懂]很早就很想写这个,今天终于写完了。游戏截图:编译环境:VS2017下面我来介绍一下游戏的主要功能和实现方式首先是玩家的定义,使用结构体,这个名字是可以自己改变的structgamerole{ charn…

    2022年5月20日
    35
  • navicat11.0激活码-激活码分享

    (navicat11.0激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlMLZPB5EL5Q-eyJsaWNlbnNlSWQi…

    2022年3月20日
    372
  • linux内核发包工具,Linux内核发包工具pktgen测试方案说明「建议收藏」

    linux内核发包工具,Linux内核发包工具pktgen测试方案说明「建议收藏」简介pktgen是Linux内核里包含的一个高性能发包工具,主要用来测试网络性能。一般情况下,使用pktgen就可以满足千兆网卡的测试需要。pktgen运行在“内核态”,并不占用太多的系统资源,就可以达到非常高的发包速率。pktgen只支持UDP发包(端口9)。因为pktgen是一个非常底层测试工具,而且一般是测试网络设备的性能,并不涉及到应用层面。如果要测试高级的网络应用的性能,请使用其它的测…

    2025年9月19日
    6
  • 浮动广告代码

    浮动广告代码整个页面的代码如下:<%@PageLanguage=’vb’AutoEventWireup=’false’Codebehind=’floatadv.aspx.vb’Inherits=’

    2022年7月3日
    26
  • PHP中unset,array_splice删除数组中元素的区别

    PHP中unset,array_splice删除数组中元素的区别

    2021年10月15日
    34
  • SQL 报错注入详解[通俗易懂]

    SQL 报错注入详解[通俗易懂]一、报错注入详解近期学习SQL报错注入,本篇文章为关于报错注入的一些个人理解,如有错误,希望指出本文使用sqli-labs数据库作为示例1、十种MySQL报错注入:报错注入方式有很多,其中比较常见的有floor()、extractvalue()、updatexml()三种,本篇文章主要对这三种进行分析,其他的请参考文章:十种MySQL报错注入2、floor()2.1、payload分析先贴上一个常见的payload再进行分析(sqli-labsLess-5)’

    2022年9月30日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号