剑指offer系列34----按之字形顺序打印二叉树
【题目】请实现一个函数按照之字形打印二叉树,
* 即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,
* 其他行以此类推。
未优化,不是最优解,博主用的是队列,我用的栈。
方法一:直接打印
- package com.exe7.offer;
- import java.util.Stack;
- import org.junit.Test;
- /**方法一:直接打印
- * 【题目】请实现一个函数按照之字形打印二叉树,
- * 即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,
- * 其他行以此类推。
- * @author WGS
- *
- */
- public class PrintBiTree {
- static class TreeNode{
- int val=0;
- TreeNode left=null;
- TreeNode right=null;
- public TreeNode(int val){
- this.val=val;
- }
- }
- public void printZhiTree(TreeNode pRoot){
- if(pRoot==null) return;
- Stack<TreeNode> stack1=new Stack<>();
- Stack<TreeNode> stack2=new Stack<>();
- stack1.push(pRoot);
- int toBePrint=1;
- int nextLevelNodes=0;
- int level=1;
- TreeNode tempNode=null;
- while(!stack1.isEmpty() || !stack2.isEmpty()){
- if(level%2!=0){
- tempNode=stack1.pop();
- System.out.print(tempNode.val+" ");
- --toBePrint;
- if(tempNode.left!=null){
- stack2.push(tempNode.left);
- ++nextLevelNodes;
- }
- if(tempNode.right!=null){
- stack2.push(tempNode.right);
- ++nextLevelNodes;
- }
- }else{
- tempNode=stack2.pop();
- System.out.print(tempNode.val+" ");
- --toBePrint;
- if(tempNode.right!=null){
- stack1.push(tempNode.right);
- ++nextLevelNodes;
- }
- if(tempNode.left!=null){
- stack1.push(tempNode.left);
- ++nextLevelNodes;
- }
- }
- //
- if(toBePrint==0){
- System.out.println("------------------");
- level++;
- toBePrint=nextLevelNodes;
- nextLevelNodes=0;
- }
- }
- }
- //测试类
- public static void main(String[] args){
- PrintBiTree p=new PrintBiTree();
- TreeNode root = new TreeNode(8);
- TreeNode node1 = new TreeNode(6);
- TreeNode node2 = new TreeNode(10);
- TreeNode node3 = new TreeNode(5);
- TreeNode node4 = new TreeNode(7);
- TreeNode node5 = new TreeNode(9);
- TreeNode node6 = new TreeNode(11);
- TreeNode node7 = new TreeNode(12);
- TreeNode node8 = new TreeNode(13);
- TreeNode node9 = new TreeNode(14);
- TreeNode node10 = new TreeNode(15);
- TreeNode node11 = new TreeNode(16);
- TreeNode node12 = new TreeNode(17);
- TreeNode node13 = new TreeNode(18);
- TreeNode node14 = new TreeNode(19);
- root.left = node1;
- root.right = node2;
- node1.left = node3;
- node1.right = node4;
- node2.left = node5;
- node2.right = node6;
- node3.left=node7;
- node3.right=node8;
- node4.left=node9;
- node4.right=node10;
- node5.left=node11;
- node5.right=node12;
- node6.left=node13;
- node6.right=node14;
- p.printZhiTree(root);
- }
- }
方法二:面试需要
- package com.exe7.offer;
- import java.util.ArrayList;
- import java.util.Stack;
- /**方法二:面试时候需要
- * 【题目】请实现一个函数按照之字形打印二叉树,
- * 即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,
- * 其他行以此类推。
- * @author WGS
- *
- */
- public class PrintBiTree2 {
- static class TreeNode{
- int val=0;
- TreeNode left=null;
- TreeNode right=null;
- public TreeNode(int val){
- this.val=val;
- }
- }
- public ArrayList<ArrayList<Integer>> printZhiTree(TreeNode pRoot){
- ArrayList<ArrayList<Integer>> list=new ArrayList<>();
- if(pRoot==null) return list;
- ArrayList<Integer> nodeList=new ArrayList<Integer>();
- Stack<TreeNode> stack1=new Stack<>();
- Stack<TreeNode> stack2=new Stack<>();
- stack1.push(pRoot);
- int toBePrint=1;
- int nextLevelNodes=0;
- int level=1;
- TreeNode tempNode=null;
- while(!stack1.isEmpty() || !stack2.isEmpty()){
- if(level%2!=0){//奇数层
- tempNode=stack1.pop();
- //System.out.print(tempNode.val+" ");
- nodeList.add(tempNode.val);
- --toBePrint;
- if(tempNode.left!=null){
- stack2.push(tempNode.left);
- ++nextLevelNodes;
- }
- if(tempNode.right!=null){
- stack2.push(tempNode.right);
- ++nextLevelNodes;
- }
- }else{
- tempNode=stack2.pop();
- //System.out.print(tempNode.val+" ");
- nodeList.add(tempNode.val);
- --toBePrint;
- if(tempNode.right!=null){
- stack1.push(tempNode.right);
- ++nextLevelNodes;
- }
- if(tempNode.left!=null){
- stack1.push(tempNode.left);
- ++nextLevelNodes;
- }
- /* if(toBePrint==0){
- System.out.println();
- list.add(nodeList);
- level++;
- toBePrint=nextLevelNodes;
- nextLevelNodes=0;
- nodeList=new ArrayList<Integer>();
- }*/
- }
- if(toBePrint==0){
- System.out.println();
- list.add(nodeList);
- level++;
- toBePrint=nextLevelNodes;
- nextLevelNodes=0;
- nodeList=new ArrayList<Integer>();
- }
- }
- return list;
- }
- //测试类
- public static void main(String[] args){
- PrintBiTree2 p=new PrintBiTree2();
- TreeNode root = new TreeNode(8);
- TreeNode node1 = new TreeNode(6);
- TreeNode node2 = new TreeNode(10);
- TreeNode node3 = new TreeNode(5);
- TreeNode node4 = new TreeNode(7);
- TreeNode node5 = new TreeNode(9);
- TreeNode node6 = new TreeNode(11);
- TreeNode node7 = new TreeNode(12);
- TreeNode node8 = new TreeNode(13);
- TreeNode node9 = new TreeNode(14);
- TreeNode node10 = new TreeNode(15);
- TreeNode node11 = new TreeNode(16);
- TreeNode node12 = new TreeNode(17);
- TreeNode node13 = new TreeNode(18);
- TreeNode node14 = new TreeNode(19);
- root.left = node1;
- root.right = node2;
- node1.left = node3;
- node1.right = node4;
- node2.left = node5;
- node2.right = node6;
- node3.left=node7;
- node3.right=node8;
- node4.left=node9;
- node4.right=node10;
- node5.left=node11;
- node5.right=node12;
- node6.left=node13;
- node6.right=node14;
- ArrayList<ArrayList<Integer>> getList=p.printZhiTree(root);;
- for(ArrayList<Integer> a:getList){
- System.out.println(a);
- }
- }
- }
剑指offer系列34----按之字形顺序打印二叉树的更多相关文章
- 剑指offer 面试题. 按之字形顺序打印二叉树
题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推. 方法1: 正常层次遍历,利用普通队列.逢 ...
- 剑指 Offer 32 - III. 从上到下打印二叉树 III + 双端队列使用 + 蛇形打印层次遍历序列 + 正倒序输出
剑指 Offer 32 - III. 从上到下打印二叉树 III Offer_32_3 题目详情 题解分析 本题我想的比较复杂,其实题目的要求只是需要遍历的结果逆序和正序交替,这个其实可以使用Coll ...
- 剑指 Offer 32 - III. 从上到下打印二叉树 III
剑指 Offer 32 - III. 从上到下打印二叉树 III 请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印, ...
- 剑指 Offer 32 - II. 从上到下打印二叉树 II + 层次遍历二叉树 + 按层存储
剑指 Offer 32 - II. 从上到下打印二叉树 II Offer_32 题目描述: 题解分析: 这道题我一开始想到的解决方法较粗暴,就是使用两个变量来记录当前层的节点数和下一层的结点数. 以上 ...
- 剑指 Offer 32 - I. 从上到下打印二叉树 + 层次遍历二叉树
剑指 Offer 32 - I. 从上到下打印二叉树 Offer_32_1 题目描述 解题思路 这题属于简单题,考察的是我们对二叉树以及层次遍历的方法. 这里只需要使用简单的队列即可完成二叉树的层次遍 ...
- 剑指 Offer 32 - II. 从上到下打印二叉树 II
剑指 Offer 32 - II. 从上到下打印二叉树 II 从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行. 例如: 给定二叉树: [3,9,20,null,null,1 ...
- 剑指 Offer 32 - I. 从上到下打印二叉树
剑指 Offer 32 - I. 从上到下打印二叉树 从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印. 例如: 给定二叉树: [3,9,20,null,null,15,7], 3 ...
- 每日一题 - 剑指 Offer 32 - III. 从上到下打印二叉树 III
题目信息 时间: 2019-06-25 题目链接:Leetcode tag:双端队列 难易程度:中等 题目描述: 请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右 ...
- 剑指offer 23:从上往下打印二叉树
题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 解题思路 按照从左往右从上到下的顺序打印节点,需要我们维护一个队列,这个队列放入元素的顺序是访问队头节点(起始先放入根节点),则若当前 ...
- 剑指offer——33分行从上到下打印二叉树
题目描述 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行. 题解: 使用BFS,按层打印即可 class Solution { public: vector<vector&l ...
随机推荐
- dedecms 列表页调用自定义字段
在列表附加字段中添加自己定义的字段 如: lwulr调用:{dede:list addfields="lwurl" channelid="1"}[field:l ...
- sk_buff 结构分析
sk_buff分析 sk_buff是Linux网络代码中最重要的结构体之一.它是Linux在其协议栈里传送的结构体,也就是所谓的“包”,在他里面包含了各层协议的头部,比如ethernet, ip ,t ...
- 八 JDBC
一 JDBC 简介 1. 作用:规避数据库的不同,为程序开发人员访问数据库提供统一的编程接口. 2. 具体作用:和数据库建立连接,发送 sql 语句,处理数据库返回的结果集. 3. 框架模式: 4. ...
- centos 主从复制
1.主服务器rpm安装mysql 2.复制一台服务器叫slave(从服务器),一会儿要用 3.在主服务器,修改my.cnf文件 找到server-id,在它的下面加上 binlog-do-db = h ...
- puppet安装配置及使用
puppet安装前准备 一.服务器信息 master端:10.10.10.201 master.fansik.com slave端:10.10.10.156 slave.fansik.com 三台机 ...
- LAMT基于mod_proxy方式的负载均衡集群
一.apache服务器 # httpd -D DUMP_MODULES | grep proxy查看是否有 proxy_balancer_module (shared)模块 二.编辑配置文件 1.编 ...
- linux笔记_磁盘分区
一.分区的意义 1.不同操作系统往往不可以同时装载在同一个分区,分区解决了不同操作系统装载在同一个物理硬盘的兼容性问题 2.机械硬盘盘片外圈读写速度相对内圈要快,分区可以把常用数据限制在读写速度较快的 ...
- spark中streamingContext的使用详解
两种创建方式 val conf = new SparkConf().setAppName(appName).setMaster(master);val ssc = new StreamingConte ...
- scala言语基础学习三(面向对象编程)
定义一个简单的类 //定义类,包含field以及方法 自定义的getter 和setter 仅仅暴露field的getter和setter方法 private[this]的使用 (只能在当前实例中使用 ...
- JAVA导入包
在package **;下面写入 import java.**.**; 1.使用Scanner工具类来获取用户输入的成绩信息 Scanner类位于java.util包中,使用时需要导入此包 1.1. ...