博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
牛客(59)按之字形顺序打印二叉树
阅读量:4957 次
发布时间:2019-06-12

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

//    题目描述//    请实现一个函数按照之字形打印二叉树,//    即第一行按照从左到右的顺序打印,//    第二层按照从右至左的顺序打印,//    第三行按照从左到右的顺序打印,//    其他行以此类推。    public class TreeNode {        int val = 0;        TreeNode left = null;        TreeNode right = null;        public TreeNode(int val) {            this.val = val;        }    }    public ArrayList
> Print(TreeNode pRoot) { ArrayList
> arrayLists = new ArrayList
>(); if (pRoot==null){ return arrayLists; } Stack
stack1 = new Stack
(); Stack
stack2 = new Stack
(); stack1.add(pRoot); while (!stack1.isEmpty() || !stack2.isEmpty()) { if (!stack1.isEmpty()) { ArrayList
arrayList = new ArrayList
(); while (!stack1.isEmpty()) { TreeNode node = stack1.pop(); arrayList.add(node.val); if (node.left != null) { stack2.add(node.left); } if (node.right != null) { stack2.add(node.right); } } arrayLists.add(arrayList); }else if (!stack2.isEmpty()) { ArrayList
arrayList = new ArrayList
(); while (!stack2.isEmpty()) { TreeNode node = stack2.pop(); arrayList.add(node.val); if (node.right != null) { stack1.add(node.right); } if (node.left != null) { stack1.add(node.left); } } arrayLists.add(arrayList); } } return arrayLists; }

 

转载于:https://www.cnblogs.com/kaibing/p/9109691.html

你可能感兴趣的文章
ORACLE 10G R2_执行计划中cost cardinality bytes cpu_cost io_cost解释
查看>>
关于this和base
查看>>
(转)Scrapy 深入一点点
查看>>
荧光激活细胞分选( FACS)
查看>>
传球游戏
查看>>
如何组建和管理测试团队
查看>>
理论相关概念原理
查看>>
本地存储
查看>>
MP3的播放与停止
查看>>
两个周末,两个湖
查看>>
开发环境搭建
查看>>
入门GTD时间管理系统必读
查看>>
Codeforces Round #367 (Div. 2) Vasiliy's Multiset 异或字典树带删除模板
查看>>
牛客(59)按之字形顺序打印二叉树
查看>>
JavaScript 图表库 xCharts
查看>>
Android项目的目录结构
查看>>
C++中“引用”的底层实现
查看>>
jquery datatable 参数
查看>>
vuex中的dispatch和commit
查看>>
mybatis实战教程二:多对一关联查询(一对多)
查看>>