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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux基本命令iscsiadm,tgtadm和iscsiadm命令的用法

    linux基本命令iscsiadm,tgtadm和iscsiadm命令的用法:关联到指定lun上的后端存储设备,此例为分区-I–initiator-address:指定可以访问Target的IP地址具体用法请mantgtadm二.iscsiadm命令iscsiadm是个模式化的工具,其模式可通过-m或–mode选项指定,常见的模式有discoverydb、node、fw、session、host、iface几个,如果没有额外指定其它选项,则discoveryd…

    2022年8月23日
    13
  • [已发表,转载勘误]Android upx脱壳「建议收藏」

    [已发表,转载勘误]Android upx脱壳「建议收藏」已发在https://www.anquanke.com/post/id/197643不过有部分内容发布之后无法编辑,勘误后如下。Androidupx脱壳写在前面因为我不是pc平台过来的,而是直接从Android入门的,所以upx壳其实一开始并不了解,后来接触到,但是可以直接动态调试或者做个内存快照,对我来说加没加upx其实对我逆向分析影响不大。另一方面upx壳因为开源且其实有很多脱壳的教…

    2022年7月19日
    20
  • java高级语言程序设计_高级程序设计语言包括

    java高级语言程序设计_高级程序设计语言包括Java程序设计(高级及专题)- XML

    2022年4月22日
    47
  • 理解Object.defineProperty方法

    理解Object.defineProperty方法nbsp nbsp 之前没怎么对 Object defineProper 方法做深入了解 就知道可以通过这个方法可以设置对象的属性 现在稍微了解以后 发现还是有不少东西值得记录一下的 所以写下这篇博客 一 语法 Object defineProper obj prop descriptor nbsp nbsp nbsp nbsp obj 需要定义属性的对象 nbsp nbsp prop 需要定义的属性 nbsp nbsp descriptor 属性的描述描述符 nbsp

    2026年2月5日
    0
  • 创建KVM虚拟机_安卓kvm虚拟机

    创建KVM虚拟机_安卓kvm虚拟机可以用两种方法创建kvm虚拟机,一种是virt-manager管理工具创建,一种是命令行的方式。1.命令行方式创建kvm虚拟机。先创建qcow2格式的镜像文件,大小为20G。qemu-imgcreate-fqcow2/data/kvm/images/centos7.6×86.qcow20G输入命令进行虚拟机的安装:virt-install–name=centos7.6×86–vcpus=2–ram=2048–diskpath=/data/kvm/imag

    2025年7月17日
    6
  • eclipse自动提示+自动补全[通俗易懂]

    eclipse自动提示+自动补全[通俗易懂]解决代码的自动提示问题:1、打开Eclipse->Window->Perferences2、找到Java下的 Editor下的 ContentAssist, 右边出现的选项中,有一个AutoactivationtriggersforJava:会看到只有一个”.”存在。表示:只有输入”.”之后才会有代码提示3、先把上图中”.”的地方输入几个随便的字

    2022年6月28日
    33

发表回复

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

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