标签:算法
问题描述:
Given a binary tree, return the level order traversal of its nodes‘ values. (ie, from left to right, level by level).
For example:
Given binary tree {3,9,20,#,#,15,7}
,
3
/ 9 20
/ 15 7
return its level order traversal as:
[
[3],
[9,20],
[15,7]
]
confused what "{1,#,2,3}"
means?
> read more on how binary tree is serialized on OJ.
代码:
/** * Definition for binary tree * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val = x; } * } */ public class Solution { public List<List<Integer>> levelOrder(TreeNode root) { //java if(root == null) return new ArrayList<>(); Stack<TreeNode> stack = new Stack<TreeNode>(); stack.add(root); List<TreeNode> levelList = new ArrayList<TreeNode>(); List<List<Integer>> result = new ArrayList<List<Integer>>(); List<List<Integer>> invert_result = new ArrayList<List<Integer>>(); List<Integer> tmp = new ArrayList<Integer>(); while(!stack.isEmpty()|| !levelList.isEmpty()){ if(stack.isEmpty()){ for(int i=levelList.size()-1; i>=0; i--) stack.push(levelList.get(i)); levelList.clear(); invert_result.add(tmp); tmp = new ArrayList<Integer>(); } while(!stack.isEmpty()){ TreeNode node = stack.pop(); tmp.add(node.val); if(node.left !=null) levelList.add(node.left); if(node.right !=null) levelList.add(node.right); } } invert_result.add(tmp); return invert_result; } }
[leetcode]Binary Tree Level Order Traversal
标签:算法
原文地址:http://blog.csdn.net/chenlei0630/article/details/40513995