剑指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;
    }
全部评论
UP主小哥哥!我知道你很忙!请百忙中给我些建议!——我是b站看到你哒!可是b站还没转正的我,只能在这里找到你了~ 本人情况:最近刚刚接触java,这个才从基础学起,看了b站上面的视频;本人研二,最近很愁暑期实习! 1、up主小哥哥,帮我判断一下,到准备暑期实习的这段时间(比如5月份需要投递了 ),是否能准备好一个可以通过的简历,能否达到找到java技术岗的能力? 2、如果不是互联网技术,如果是其他企业技术岗位,这个时间是可以充足准备暑期实习技术岗位的吗? 3、如果真的是可能起步的有些晚,不太清楚暑期应该怎么投呢?是投非技术岗位,还是就用这两个月的时间去准备投一个技术岗位?因为我的目标是技术岗,但不限于互联网,我会更偏重国企这些,所以不知道,我的暑期目标应该怎么定?
点赞 回复
分享
发布于 2020-03-22 20:45
代码还可以改进一下,循环里面取node节点时直接从队列里面poll就好
点赞 回复
分享
发布于 2020-08-19 10:01
滴滴
校招火热招聘中
官网直投

相关推荐

投递腾讯云智研发等公司9个岗位
点赞 评论 收藏
转发
2 1 评论
分享
牛客网
牛客企业服务