博客
关于我
按之字形顺序打印二叉树
阅读量:412 次
发布时间:2019-03-06

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

请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推

解题思路

这道题可以借助两个栈来实现,用文字不好描述,也许直接看代码会好一些

import java.util.ArrayList;import java.util.Stack;public class Solution {    public ArrayList
> Print(TreeNode pRoot) { // 用来存放结点 ArrayList
> list = new ArrayList<>(); if(pRoot == null) { return list; } // 判断奇偶层 int layer = 1; // 存放奇数层结点 Stack
s1 = new Stack<>(); // 存放偶数层结点 Stack
s2 = new Stack<>(); // 先把根结点放入奇数层 s1.push(pRoot); // 如果两个栈都为空,那么就证明所有结点都已遍历完毕 while(!s1.empty() || !s2.empty()) { // 当前层是奇数层 if(layer % 2 != 0) { // 存放奇数层的结点 ArrayList
temp = new ArrayList<>(); // 把奇数层的结点逐个弹出,用 temp 保存起来 // 同时把每个弹出结点的左右子结点压入栈 // 要注意栈的特点是后进先出,因此出栈顺序和入栈顺序是相反的 while(!s1.empty()) { TreeNode node = s1.pop(); if(node != null) { temp.add(node.val); s2.push(node.left); s2.push(node.right); } } if(!temp.isEmpty()) { list.add(temp); layer++; } } else { // 原理同上 ArrayList
temp = new ArrayList<>(); while(!s2.empty()) { TreeNode node = s2.pop(); if(node != null) { temp.add(node.val); s1.push(node.right); s1.push(node.left); } } if(!temp.isEmpty()) { list.add(temp); layer++; } } } return list; }}

转载地址:http://vwnkz.baihongyu.com/

你可能感兴趣的文章
MySQL优化之BTree索引使用规则
查看>>
MySQL优化之推荐使用规范
查看>>
Webpack Critical CSS 提取与内联教程
查看>>
mysql优化概述(范式.索引.定位慢查询)
查看>>
MySQL优化的一些需要注意的地方
查看>>
mysql优化相关
查看>>
MySql优化系列-优化版造数据(存储过程+函数+修改存储引擎)-2
查看>>
MySql优化系列-进阶版造数据(load data statment)-3
查看>>
MySql优化系列-造数据(存储过程+函数)-1
查看>>
MySQL优化配置详解
查看>>
Mysql优化高级篇(全)
查看>>
mysql会员求积分_MySql-统计所有会员的最高前10次的积分和
查看>>
mysql会对联合索性排序优化_MySQL索引优化实战
查看>>
MySQL作为服务端的配置过程与实际案例
查看>>
Mysql使用命令行备份数据
查看>>
MySQL保姆级教程(SQL语法基础篇)从小白到高手的进阶指南,收藏这一篇就够了
查看>>
MySQL修改root密码的各种方法
查看>>
MySQL修改root密码的多种方法
查看>>
mysql修改一列属性
查看>>
MySQL修改密码报错ERROR 1396 (HY000): Operation ALTER USER failed for ‘root‘@‘localhost‘
查看>>