二叉树的逆层序遍历

二叉树的逆层序遍历

问题

这个题目说的是,给你一棵二叉树,要求你从叶子节点到根节点一层一层地对其进行访问,对于每一层的节点,则是从左向右进行访问。将访问的结果以二维数组返回。

这道题目和二叉树层序遍历的唯一区别是,它是从下向上一层一层去访问的。

比如说,给你的二叉树是:

     1
   /   \
  2     4
       / \
      8  16

它的逆层序遍历结果是:

[
 [8, 16],
 [2, 4],
 [1],
]

代码

public class AlgoCasts {

  public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;

    TreeNode(int x) {
      val = x;
    }
  }

  // Time: O(n), Space: O(n)
  public List<List<Integer>> levelOrderTraversalFromBottom(TreeNode root) {
    if (root == null) return new ArrayList<>();
    List<List<Integer>> result = new ArrayList<>();
    Queue<TreeNode> q = new LinkedList<>();
    q.add(root);

    while (!q.isEmpty()) {
      List<Integer> elem = new ArrayList<>();
      int size = q.size();
      for (int i = 0; i < size; ++i) {
        TreeNode s = q.poll();
        elem.add(s.val);
        if (s.left != null) q.add(s.left);
        if (s.right != null) q.add(s.right);
      }
      result.add(elem);
    }

    for (int i = 0; i < result.size()/2; ++i) {
      int j = result.size() - 1 - i;
      List<Integer> tmp = result.get(j);
      result.set(j, result.get(i));
      result.set(i, tmp);
    }
    return result;
  }

}

  转载请注明: ForwardXu 二叉树的逆层序遍历

 上一篇
用前序和中序遍历序列构建二叉树 用前序和中序遍历序列构建二叉树
用前序和中序遍历序列构建二叉树问题 这个题目说的是,给你一棵二叉树的前序和中序遍历序列,你要根据这两个序列构建这棵二叉树。假设这棵二叉树节点上没有重复的数字。 比如说,给你的前序遍历序列和中序遍历序列分别是: 前序遍历序列:1, 2, 4
2018-12-28
下一篇 
二叉树的最大深度 二叉树的最大深度
二叉树的最大深度问题 这个题目说的是,给你一棵二叉树,你要找到从根节点到最远叶子节点的深度。 比如说,给你的二叉树是 1 / \ 2 4 / \ 8 16 这棵树有 3 个叶子节点,分别
2018-12-28
  目录