剑指offer系列33-----把二叉树打印成多行
【题目】从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。
方法一:直接打印
package com.exe7.offer; import java.util.LinkedList;
import java.util.Queue; /**
* 【题目】从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。
* @author WGS
*
*/
public class PrintBiTreeFromTopToBottom {
static class TreeNode{
int val=0;
TreeNode left=null;
TreeNode right=null;
public TreeNode(int val){
this.val=val;
}
} public void printBiTreeFromTopToBottom(TreeNode headNode){
if(headNode==null) return ;
int nextLevelNodes=0;
int toBoPrint=1;//设置个初始值
Queue<TreeNode> queue=new LinkedList<TreeNode>();
queue.add(headNode);
while(!queue.isEmpty()){
//1 打印
TreeNode curNode=queue.poll();
System.out.print(curNode.val+" "); //2 添加左右结点
if(curNode.left!=null){
queue.add(curNode.left);
nextLevelNodes++;//下层要打印的结点数+1
}
if(curNode.right!=null){
queue.add(curNode.right);
nextLevelNodes++;//下层要打印的结点数+1
}
//左右结点添加完后即打印完本层一个结点值,自动减1(要判断本层是否还有别的值)
--toBoPrint;
if(toBoPrint==0){//本层打印完
System.out.println();//换行
toBoPrint=nextLevelNodes;//下层要打印的结点数
nextLevelNodes=0;//清0
}
} }
public static void main(String[] args) {
PrintBiTreeFromTopToBottom p=new PrintBiTreeFromTopToBottom();
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); root.left = node1;
root.right = node2;
node1.left = node3;
node1.right = node4;
node2.left = node5;
node2.right = node6; p.printBiTreeFromTopToBottom(root);
} }
方法二:使用博主的方法(面试时候推荐此种方法,个别代码差异,思想一样)
package com.exe7.offer; import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue; /**方法二:使用博主的方法(面试时候推荐此种方法,个别代码差异,思想一样)
* 【题目】从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。
* @author WGS
*
*/
public class PrintBiTreeFromTopToBottom2 {
static class TreeNode{
int val=0;
TreeNode left=null;
TreeNode right=null;
public TreeNode(int val){
this.val=val;
}
} public ArrayList<ArrayList<Integer>> printBiTreeFromTopToBottom(TreeNode headNode){
ArrayList<ArrayList<Integer>> list=new ArrayList<>();//接收总共行的结点
ArrayList<Integer> nodeList=new ArrayList<>();//接收每行结点
if(headNode==null) return list;
int nextLevelNodes=0;//下层要打印的结点数
int toBoPrint=1;//设置个初始值
Queue<TreeNode> queue=new LinkedList<TreeNode>();
queue.add(headNode);
while(!queue.isEmpty()){
//1 打印
TreeNode curNode=queue.poll();
//System.out.print(curNode.val+" ");
nodeList.add(curNode.val);
//2 添加左右结点
if(curNode.left!=null){
queue.add(curNode.left);
nextLevelNodes++;//下层要打印的结点数+1
}
if(curNode.right!=null){
queue.add(curNode.right);
nextLevelNodes++;//下层要打印的结点数+1
}
//左右结点添加完后即打印完本层一个结点值,自动减1(要判断本层是否还有别的值)
--toBoPrint;
if(toBoPrint==0){//本层打印完
//System.out.println();//换行
list.add(nodeList);
toBoPrint=nextLevelNodes;//下层要打印的结点数
nextLevelNodes=0;//清0
nodeList=new ArrayList<>();
}
}
return list; }
public static void main(String[] args) {
PrintBiTreeFromTopToBottom2 p=new PrintBiTreeFromTopToBottom2();
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); root.left = node1;
root.right = node2;
node1.left = node3;
node1.right = node4;
node2.left = node5;
node2.right = node6; ArrayList<ArrayList<Integer>> getList=p.printBiTreeFromTopToBottom(root);
for (ArrayList<Integer> arrayList : getList) {
System.out.println(arrayList);
}
} }
剑指offer系列33-----把二叉树打印成多行的更多相关文章
- 剑指offer系列32-----对称二叉树的判断
[题目]请实现一个函数,用来判断一颗二叉树是不是对称的.注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的. package com.exe7.offer; /** * [题目]请实现一个函 ...
- 剑指offer系列53---字符串转化成整数
[题目]将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数 * []整数(32位)最大值:0X7fff ffff( 0111 1111 1111 1111 1111 1111 1111 1 ...
- 剑指offer系列——二维数组中,每行从左到右递增,每列从上到下递增,设计算法找其中的一个数
题目:二维数组中,每行从左到右递增,每列从上到下递增,设计一个算法,找其中的一个数 分析: 二维数组这里把它看作一个矩形结构,如图所示: 1 2 8 2 4 9 12 4 7 10 13 6 8 11 ...
- 剑指Offer:二叉树打印成多行【23】
剑指Offer:二叉树打印成多行[23] 题目描述 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行. 题目分析 Java题解 package tree; import java.uti ...
- 把二叉树打印成多行 牛客网 剑指Offer
把二叉树打印成多行 牛客网 剑指Offer 题目描述 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行 # class TreeNode: # def __init__(self, x) ...
- 【剑指Offer】把二叉树打印成多行 解题报告(Python)
[剑指Offer]把二叉树打印成多行 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-interviews ...
- 剑指Offer - 九度1368 - 二叉树中和为某一值的路径
剑指Offer - 九度1368 - 二叉树中和为某一值的路径2013-11-23 03:46 题目描述: 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结 ...
- 干货 | 剑指offer系列文章汇总
下面是名企面试中经常会出现的面试题目,大家可以戳相应的题目查看题目细节,其答案会在紧接着的后一篇中出现 剑指offer系列 始 剑指offer—灯管问题(1) 剑指offer—10人电梯(2) ...
- 《剑指offer》从尾到头打印链表
本题来自<剑指offer> 从尾到头打印链表 题目: 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList. 思路: 方案一:首先遍历到尾部,然后从尾部进行到头值进行操作,后进先 ...
- 剑指Offer - 九度1521 - 二叉树的镜像
剑指Offer - 九度1521 - 二叉树的镜像2013-11-30 23:32 题目描述: 输入一个二叉树,输出其镜像. 输入: 输入可能包含多个测试样例,输入以EOF结束.对于每个测试案例,输入 ...
随机推荐
- Quantum & r2q
Quantum & r2q Let's assume we have 2 classes with the same parent : Parent : ceil = rate = 100 c ...
- MapReduce 计算模型
前言 本文讲解Hadoop中的编程及计算模型MapReduce,并将给出在MapReduce模型下编程的基本套路. 模型架构 在Hadoop中,用于执行计算任务(MapReduce任务)的机器有两个角 ...
- hdu 5091 Beam Cannon
题目大意: 有n个点(n<=10000),点的坐标绝对值不超过20000,然后问你用一个w*h(1<=w,h<=40000)的矩形,矩形的边平行于坐标轴,最多能盖住多少个点. 刘汝佳 ...
- 关于typedef的用法总结(转)
不管实在C还是C++代码中,typedef这个词都不少见,当然出现频率较高的还是在C代码中.typedef与#define有些相似,但更多的是不同,特别是在一些复杂的用法上,就完全不同了,看了网上一些 ...
- BIOS设置
主界面: 标准BLOS设置: 高级BLOS设置: 1.设置从光盘驱动 电脑启动时默认是从硬盘启动,但是在安装操作系统时或者是使用某些特殊软件时,可能需要从光盘.软盘或者U盘启动,这时就需要设置第一启 ...
- Git常用命令总结(超实用)
导读 Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目.一般来说,日常使用Git只要记住下图6个命令,就可以了.但是熟练使用,恐怕要记住60-100个命令. 下面是我整 ...
- jquery】常用的jquery获取表单对象的属性与值
[jquery]常用的jquery获取表单对象的属性与值 1.JQuery的概念 JQuery是一个JavaScript的类库,这个类库集合了很多功能方法,利用类库你可以用一些简单的代码实现一些复杂的 ...
- 【HAOI2006】【BZOJ1051】【p1233】最受欢迎的牛
BZOJ难得的水题(其实是HA太弱了) 原题: 每一头牛的愿望就是变成一头最受欢迎的牛.现在有N头牛,给你M对整数(A,B),表示牛A认为牛B受欢迎. 这 种关系是具有传递性的,如果A认为B受欢迎,B ...
- Ghost的相关问题
一些和Ghost使用有关的问题,记录在这里. 1,有时候使用ghost恢复,发现最后一步选择驱动器是灰色的,这是因为备份文件有些是用Disk模式,有些使用partition模式,所有恢复的时候如果其中 ...
- java的nio之:java的bio流下实现的socket服务器同步阻塞模型和socket的伪异步的socket服务器的通信模型
同步I/O模型的弊端===>每一个线程的创建都会消耗服务端内存,当大量请求进来,会耗尽内存,导致服务宕机 伪异步I/O的弊端分析===>当对Socket的输入流进行读取操作的时候,它会一直 ...