剑指offer-从上往下打印二叉树-Java版
从上往下打印二叉树
http://www.nowcoder.com/questionTerminal/7fe2212963db4790b57431d9ed259701
写在前面
代码说明:代码的下载地址: 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; }