本文首發于我的個人部落格: 尾尾部落
題目描述
從上到下按層列印二叉樹,同一層結點從左至右輸出。每一層輸出一行。
解題思路
就是二叉樹的層序周遊,用隊列來實作。我們需要兩個變量,一個start記錄目前層已經列印的節點個數,一個end記錄前當層所有的節點個數,當 start == end 時,表時目前層周遊完了,就可以開始下一層周遊。
參考代碼
import java.util.ArrayList;
import java.util.Queue;
import java.util.LinkedList;
/*
public class TreeNode {
int val = 0;
TreeNode left = null;
TreeNode right = null;
public TreeNode(int val) {
this.val = val;
}
}
*/
public class Solution {
ArrayList<ArrayList<Integer> > Print(TreeNode pRoot) {
ArrayList<ArrayList<Integer> > res = new ArrayList<ArrayList<Integer> >();
if(pRoot == null)
return res;
ArrayList<Integer> temp = new ArrayList<Integer>();
Queue<TreeNode> layer = new LinkedList<TreeNode>();
layer.offer(pRoot);
int start = 0, end = 1;
while(!layer.isEmpty()){
TreeNode node = layer.poll();
temp.add(node.val);
start ++;
if(node.left != null)
layer.add(node.left);
if(node.right != null)
layer.add(node.right);
if(start == end){
start = 0;
res.add(temp);
temp = new ArrayList<Integer>();
end = layer.size();
}
}
return res;
}
}