《剑指offer》之从上到下打印二叉树Ⅰ、Ⅱ、Ⅲ

简介: 《剑指offer》之从上到下打印二叉树Ⅰ、Ⅱ、Ⅲ

《剑指offer》之从上到下打印二叉树Ⅰ、Ⅱ、Ⅲ

1 从上到下打印二叉树Ⅰ

1.1 题目

https://leetcode-cn.com/problems/cong-shang-dao-xia-da-yin-er-cha-shu-lcof/

1.2 思路

网络异常,图片无法展示
|


1.3 题解

二叉树类(下同):

/**
 * @desc: 二叉树类
 * @author: YanMingXin
 * @create: 2021/9/13-15:52
 **/
public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;
    TreeNode(int x) {
        val = x;
    }
}
复制代码

算法代码:

/**
 * @desc: 剑指 Offer 32 - I. 从上到下打印二叉树
 * @author: YanMingXin
 * @create: 2021/9/13-14:28
 **/
public class Test01 {
    /**
     * 声明队列
     */
    private Queue<TreeNode> queue = new LinkedList<>();
    /**
     * 声明有序列表
     */
    private ArrayList<Integer> list = new ArrayList<>();
    /**
     * BFS解决
     *
     * @param root
     * @return
     */
    public int[] levelOrder(TreeNode root) {
        //判断临界值
        if (root == null) {
            return new int[0];
        }
        //将root放在队首
        queue.add(root);
        //进行循环
        while (!queue.isEmpty()) {
            //弹出队首元素放在List中
            TreeNode node = queue.poll();
            list.add(node.val);
            //广度优先搜索
            if (node.left != null) {
                queue.add(node.left);
            }
            if (node.right != null) {
                queue.add(node.right);
            }
        }
        //将List换成数组
        int[] res = new int[list.size()];
        for (int i = 0; i < list.size(); i++) {
            res[i] = list.get(i);
        }
        return res;
    }
}
复制代码

2 从上到下打印二叉树Ⅱ

2.1 题目

https://leetcode-cn.com/problems/cong-shang-dao-xia-da-yin-er-cha-shu-ii-lcof/

2.2 思路

网络异常,图片无法展示
|


2.3 题解

/**
 * @desc: 剑指 Offer 32 - II. 从上到下打印二叉树 II
 * @author: YanMingXin
 * @create: 2021/9/13-14:52
 **/
public class Test02 {
    /**
     * 声明嵌套链表
     */
    private ArrayList<List<Integer>> list = new ArrayList<>();
    /**
     * 声明队列
     */
    private Queue<TreeNode> queue = new LinkedList<>();
    /**
     * BFS
     *
     * @param root
     * @return
     */
    public List<List<Integer>> levelOrder(TreeNode root) {
        //临界条件
        if (root != null) {
            queue.add(root);
        }
        while (!queue.isEmpty()) {
            List<Integer> tmp = new ArrayList<>();
            //将队列中的元素全部弹出
            for (int i = queue.size(); i > 0; i--) {
                TreeNode node = queue.poll();
                //list添加队列中弹出的元素
                tmp.add(node.val);
                //向队列添加新的元素,留作下次循环使用
                if (node.left != null) {
                    queue.add(node.left);
                }
                if (node.right != null) {
                    queue.add(node.right);
                }
            }
            list.add(tmp);
        }
        return list;
    }
}
复制代码

3 从上到下打印二叉树Ⅲ

3.1 题目

https://leetcode-cn.com/problems/cong-shang-dao-xia-da-yin-er-cha-shu-iii-lcof/

3.2 思路

何为双端队列?

双端队列顾名思义就是既可以在队首插入也可以在队尾弹出的队列。

因此如果想要达到题目的要求,就可以先判断是奇数还是偶数,并进行队首插入或队尾插入。

网络异常,图片无法展示
|


3.3 题解

/**
 * @desc: 剑指 Offer 32 - III. 从上到下打印二叉树 III
 * @author: YanMingXin
 * @create: 2021/9/13-15:08
 **/
public class Test03 {
    /**
     * 声明双端队列
     */
    private Queue<TreeNode> queue = new LinkedList<>();
    /**
     * 嵌套List
     */
    private List<List<Integer>> res = new ArrayList<>();
    /**
     * BFS+双端队列
     *
     * @param root
     * @return
     */
    public List<List<Integer>> levelOrder(TreeNode root) {
        if (root != null) {
            queue.add(root);
        }
        while (!queue.isEmpty()) {
            LinkedList<Integer> tmp = new LinkedList<>();
            for (int i = queue.size(); i > 0; i--) {
                TreeNode node = queue.poll();
                if (res.size() % 2 == 0) {
                    // 偶数层 -> 队列头部
                    tmp.addLast(node.val);
                } else {
                    // 奇数层 -> 队列尾部
                    tmp.addFirst(node.val);
                }
                if (node.left != null) {
                    queue.add(node.left);
                }
                if (node.right != null) {
                    queue.add(node.right);
                }
            }
            res.add(tmp);
        }
        return res;
    }
}


相关文章
|
4天前
|
云安全 监控 安全
|
2天前
|
存储 机器学习/深度学习 人工智能
打破硬件壁垒!煎饺App:强悍AI语音工具,为何是豆包AI手机平替?
直接上干货!3000 字以上长文,细节拉满,把核心功能、使用技巧和实测结论全给大家摆明白,读完你就知道这款 “安卓机通用 AI 语音工具"——煎饺App它为何能打破硬件壁垒?它接下来,咱们就深度拆解煎饺 App—— 先给大家扒清楚它的使用逻辑,附上“操作演示”和“🚀快速上手不踩坑 : 4 条核心操作干货(必看)”,跟着走零基础也能快速上手;后续再用真实实测数据,正面硬刚煎饺 App的语音助手口令效果——创建京东「牛奶自动下单神器」口令 ,从修改口令、识别准确率到场景实用性,逐一测试不掺水,最后,再和豆包 AI 手机语音助手的普通版——豆包App对比测试下,简单地谈谈煎饺App的能力边界在哪?
|
9天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1165 7
|
11天前
|
机器学习/深度学习 人工智能 数据可视化
1秒生图!6B参数如何“以小博大”生成超真实图像?
Z-Image是6B参数开源图像生成模型,仅需16GB显存即可生成媲美百亿级模型的超真实图像,支持中英双语文本渲染与智能编辑,登顶Hugging Face趋势榜,首日下载破50万。
735 42
|
15天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
1178 41
|
15天前
|
人工智能 前端开发 算法
大厂CIO独家分享:AI如何重塑开发者未来十年
在 AI 时代,若你还在紧盯代码量、执着于全栈工程师的招聘,或者仅凭技术贡献率来评判价值,执着于业务提效的比例而忽略产研价值,你很可能已经被所谓的“常识”困住了脚步。
942 78
大厂CIO独家分享:AI如何重塑开发者未来十年
|
3天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
|
2天前
|
人工智能 JSON 前端开发
为什么你的API文档总是被吐槽?用这份"契约指令"终结前后端战争
本文针对前后端协作中"文档过时、不准确"的痛点,提供了一套实战验证的AI指令。通过强制结构化输入和自检机制,让AI自动生成包含完整参数、JSON示例和多语言代码的标准API契约文档,彻底解决接口沟通难题。
174 112
|
11天前
|
存储 自然语言处理 测试技术
一行代码,让 Elasticsearch 集群瞬间雪崩——5000W 数据压测下的性能避坑全攻略
本文深入剖析 Elasticsearch 中模糊查询的三大陷阱及性能优化方案。通过5000 万级数据量下做了高压测试,用真实数据复刻事故现场,助力开发者规避“查询雪崩”,为您的业务保驾护航。
563 32