剑指Offer-Java-从上往下打印二叉树

举报
水坚石青 发表于 2021/10/29 23:07:21 2021/10/29
1.7k+ 0 0
【摘要】 从上往下打印二叉树 题目: 从上往下打印出二叉树的每个节点,同层节点从左至右打印。 代码: package com.sjsq.test; import java.util.Arr...

从上往下打印二叉树


题目:
从上往下打印出二叉树的每个节点,同层节点从左至右打印。
代码:

package com.sjsq.test;

import java.util.ArrayList;
import java.util.Deque;
import java.util.LinkedList;

/**
 * @author shuijianshiqing
 * @date 2020/5/24 10:43
 */

/**
 * 从上往下打印出二叉树的每个节点,同层节点从左至右打印。
 */

public class Solution {

    public ArrayList<Integer> PrintFromTopToBottom(TreeNode root) {

        // 定义双向队列
        Deque<TreeNode> deque = new LinkedList<>();
        // 定义数组来存放结果
        ArrayList<Integer> result = new ArrayList<>();

        if(root == null){
            return result;
        }

        deque.add(root);

        while(!deque.isEmpty()){
            TreeNode node = deque.getFirst();
            deque.pollFirst();
            result.add(node.val);

            // 判断有没有左子树
            if(node.left != null){
                deque.addLast(node.left);
            }

            // 判断有没有右子树
            if(node.right != null){
                deque.addLast(node.right);
            }
        }

        return result;
    }
}
  
 

文章来源: blog.csdn.net,作者:水坚石青,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/helongqiang/article/details/106311681

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。