栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

java编程题之从上往下打印出二叉树

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java编程题之从上往下打印出二叉树

本文实例为大家分享了java从上往下打印出二叉树的具体代码,供大家参考,具体内容如下

github:剑指offer编程全部试题 

import java.util.ArrayList;
import java.util.Stack;



public class Test22 {

 ArrayList arrayList = new ArrayList<>();
 // 每层依次入栈
 Stack stack1 = new Stack<>();
 // 从stack1出栈的元素依次加入stack2,统一通过stack2找到他们的字节点并压入stack1
 Stack stack2 = new Stack<>();

 public ArrayList PrintFromTopToBottom(TreeNode root) {

 if (root == null) {
 return arrayList;// 空则返回
 }
 stack1.push(root);
 while (!stack1.isEmpty()) {
 while (!stack1.isEmpty()) {
 TreeNode tmp = stack1.pop();
 arrayList.add(tmp.val);
 stack2.push(tmp);
 }
 while (!stack2.isEmpty()) {
 TreeNode tmp2 = stack2.pop();
 // 从左到右打印,所以右子树先入栈
 if (tmp2.right != null) {
 stack1.push(tmp2.right);
 }
 if (tmp2.left != null) {
 stack1.push(tmp2.left);
 }
 }
 }

 return arrayList;

 }

 public class TreeNode {
 int val = 0;
 TreeNode left = null;
 TreeNode right = null;

 public TreeNode(int val) {
 this.val = val;

 }
 }

}
//其他方法


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/138890.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号