LeetCode--No.107--Binary Tree Level Order Traversal II
2016-07-22 02:23
381 查看
Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left to right, level by level from leaf to root).
For example:
Given binary tree
return its bottom-up level order traversal as:
代码我直接照着Binary Tree Level Order Traversal I 改的
就是将最后的list倒过来。。。
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
public class Solution {
public List<List<Integer>> levelOrderBottom(TreeNode root) {
LinkedList<List<Integer>> tmp = new LinkedList<List<Integer>>();
List<List<Integer>> res = new ArrayList<List<Integer>>();
if(root == null)
return res;
List<TreeNode> currlayer= new ArrayList<TreeNode>();
currlayer.add(root);
while(!currlayer.isEmpty()){
List<TreeNode> nextlayer = new ArrayList<TreeNode>();
List<Integer> currvalue = new ArrayList<Integer>();
for(TreeNode node : currlayer){
currvalue.add(node.val);
if(node.left != null)
nextlayer.add(node.left);
if(node.right != null)
nextlayer.add(node.right);
}
tmp.add(currvalue);
currlayer = nextlayer;
}
while(!tmp.isEmpty()){
List<Integer> list = tmp.removeLast();
res.add(list);
}
return res;
}
}
For example:
Given binary tree
[3,9,20,null,null,15,7],
3 / \ 9 20 / \ 15 7
return its bottom-up level order traversal as:
[ [15,7], [9,20], [3] ]
代码我直接照着Binary Tree Level Order Traversal I 改的
就是将最后的list倒过来。。。
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
public class Solution {
public List<List<Integer>> levelOrderBottom(TreeNode root) {
LinkedList<List<Integer>> tmp = new LinkedList<List<Integer>>();
List<List<Integer>> res = new ArrayList<List<Integer>>();
if(root == null)
return res;
List<TreeNode> currlayer= new ArrayList<TreeNode>();
currlayer.add(root);
while(!currlayer.isEmpty()){
List<TreeNode> nextlayer = new ArrayList<TreeNode>();
List<Integer> currvalue = new ArrayList<Integer>();
for(TreeNode node : currlayer){
currvalue.add(node.val);
if(node.left != null)
nextlayer.add(node.left);
if(node.right != null)
nextlayer.add(node.right);
}
tmp.add(currvalue);
currlayer = nextlayer;
}
while(!tmp.isEmpty()){
List<Integer> list = tmp.removeLast();
res.add(list);
}
return res;
}
}
相关文章推荐
- JAVA集合复习
- LeetCode 235. Lowest Common Ancestor of a Binary Search Tree
- LeetCode 198. House Robber
- LeetCode 232. Implement Queue using Stacks
- LeetCode 110. Balanced Binary Tree
- Web---演示Servlet的相关类、下载技术、线程问题、自定义404页面
- LeetCode 118. Pascal’s Triangle
- Web---演示Servlet的相关类、下载技术、线程问题、自定义404页面
- LeetCode 172. Factorial Trailing Zeroes
- JAVA排序的一些总结吧
- LeetCode 260. Single Number III
- LeetCode 136. Single Number
- LeetCode 338. Counting Bits
- LeetCode 137. Single Number II
- LeetCode 141. Linked List Cycle
- LeetCode 268. Missing Number
- LeetCode 75. Sort Colors
- LeetCode 162. Find Peak Element
- LeetCode 80. Remove Duplicates from Sorted Array II
- LeetCode 48. Rotate Image