剑指Offer_60_把二叉树打印成多行
题目描述
从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。
解题思路
这题是二叉树的层序遍历,每层打印一行,每次需要记录下一次打印的个数,其余和层序遍历相同。
实现
/*树结点定义*/
public class TreeNode {
int val = 0;
TreeNode left = null;
TreeNode right = null;
public TreeNode(int val) {
this.val = val;
}
}
/*实现*/
import java.util.ArrayList;
public class Solution {
public ArrayList<ArrayList<Integer> > Print(TreeNode pRoot) {
ArrayList<ArrayList<Integer>> lists = new ArrayList<ArrayList<Integer>>();
ArrayList<TreeNode> nodes = new ArrayList<TreeNode>();
//每个ArrayList保存一行树节点
if (pRoot == null) return lists;
nodes.add(pRoot);
int count = 1; //指示每层的个数
ArrayList<Integer> list = null;
while (nodes.size() > 0){
int cNow = 0; //记录下一层的节点数
list = new ArrayList<Integer>();
for (int i = 0; i < count; i++){
if (nodes.size() > 0){
TreeNode remove = nodes.remove(0);
list.add(remove.val);
if (remove.left != null){
nodes.add(remove.left);
cNow ++;
}
if (remove.right != null){
nodes.add(remove.right);
cNow ++;
}
}
}
count = cNow;
lists.add(list);
}
return lists;
}
}