剑指offer 58:按之字形顺序打印二叉树
程序员文章站
2024-02-26 09:53:10
...
题目描述
请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推。
思路:
- 如果是直接打印二叉树的话,可以直接把每一层都存进集合然后输出总的集合
- 而这个是分层的,第一行和第二行输出顺序相反,所以借助一个boolean来标志奇偶层,然后奇数层顺序加入集合,偶数层反序加入集合,然后每一层完就加入大的集合,最后输出大的集合就可以了
import java.util.ArrayList;
import java.util.ArrayList;
import java.util.Iterator;
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 {
public ArrayList<ArrayList<Integer> > Print(TreeNode pRoot) {
ArrayList<ArrayList<Integer>> ret = new ArrayList<>();
if (pRoot == null) {
return ret;
}
ArrayList<Integer> list = new ArrayList<>();
LinkedList<TreeNode> queue = new LinkedList<>();
queue.addLast(null);//层分隔符
queue.addLast(pRoot);
boolean leftToRight = true;
//起始就有个null所以会进入循环
while (queue.size() != 1) {
TreeNode node = queue.removeFirst();
if (node == null) {//到达层分隔符
Iterator<TreeNode> iter = null;
if (leftToRight) {
iter = queue.iterator();//从前往后遍历
} else {
iter = queue.descendingIterator();//从后往前遍历
}
leftToRight = !leftToRight;
while (iter.hasNext()) {
TreeNode temp = (TreeNode)iter.next();
list.add(temp.val);
}
ret.add(new ArrayList<Integer>(list));
list.clear();
queue.addLast(null);//添加层分隔符
continue;//一定要continue
}
if (node.left != null) {
queue.addLast(node.left);
}
if (node.right != null) {
queue.addLast(node.right);
}
}
return ret;
}
}
上一篇: 桶排序-超级容易上手的一种排序
推荐阅读
-
剑指offer 58:按之字形顺序打印二叉树
-
剑指offer59:按之字形顺序打印二叉树:[[1], [3,2], [4,5,6,7]]
-
剑指offer27:按字典序打印出该字符串中字符的所有排列
-
PHP实现按之字形顺序打印二叉树的方法
-
剑指offer33:求按从小到大的顺序的第N个丑数。
-
PHP实现按之字形顺序打印二叉树的方法
-
leetcode 面试题32 (剑指offer)- II. 从上到下打印二叉树 II(python3)
-
【剑指offer刷题】--从上往下打印二叉树
-
剑指offer:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
-
剑指offer_输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字...