
题目描述:Given a binary tree, return the level order traversal of its nodes’ values. (ie, from left to right, level by level).
很简单的层级顺序遍历,思路是构造一个队列,先放入root节点,
第一次遍历把root节点的左右节点放进去,下一次遍历就是root节点的左右节点的子节点……依次类推。
public class BinaryTreeLevelOrderTraversal {
public List<List<Integer>> levelOrder(TreeNode root) {
List<List<Integer>> result = new ArrayList<>();
if(root == null)
return result;
Queue<TreeNode> queue = new LinkedList<>();
queue.add(root);
while(queue.peek() != null)
{
int size = queue.size();
List<Integer> list = new ArrayList<>();
for (int i = 0;i < size;i++)
{
TreeNode p = queue.poll();
list.add(p.val);
if(p.left != null)
queue.add(p.left);
if(p.right != null)
queue.add(p.right);
}
result.add(list);
}
return result;
}
private class TreeNode {
int val;
TreeNode left;
TreeNode right;
TreeNode(int x) { val = x; }
}
}




近期评论