写在前面
代码说明:代码的下载地址: https://github.com/WuNianLuoMeng/Coding
视频说明:第一次以这样的形式录视频,如果有哪里说的不对,还请各位及时指出,谢谢~
从上往下打印二叉树 视频链接
方法一:利用queue去模拟对二叉树宽搜的过程。进而得到二叉树的层序遍历。
public ArrayList<Integer> PrintFromTopToBottom(TreeNode root) {
ArrayList<Integer> ans = new ArrayList<>();
Queue<TreeNode> queue = new LinkedList<>(); // 放入遍历二叉树的节点(本质上是维护宽搜)
if (root != null) {
queue.add(root);
}
// 迭代的过程->宽搜
while (!queue.isEmpty()) {
TreeNode node = queue.peek();
ans.add(node.val); // 将当前节点的val值放入ArrayList中
// 同层节点从左至右打印
if (node.left != null) {
queue.add(node.left);
}
if (node.right != null) {
queue.add(node.right);
}
queue.poll(); // 当前节点val值已经放入ans中,所以要删去
}
return ans;
} 
京公网安备 11010502036488号