码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【广度优先搜索】leetcode 515. 在每个树行中找最大值


    515. 在每个树行中找最大值

    文章目录

    • 题目描述
      • 示例1:
      • 示例2:
      • 提示
    • 方法:广度优先搜索
      • 解题思路
      • 代码
      • 复杂度分析

    题目描述

    给定一棵二叉树的根节点 r o o t root root ,请找出该二叉树中每一层的最大值。

    示例1:

    在这里插入图片描述

    输入: root = [1,3,2,5,3,null,9]
    输出: [1,3,9]

    示例2:

    输入: root = [1,2,3]
    输出: [1,3]

    提示

    • 二叉树的节点个数的范围是 [ 0 , 1 0 4 ] 二叉树的节点个数的范围是 [0,10^4] 二叉树的节点个数的范围是[0,104]
    • − 2 31 < = N o d e . v a l < = 2 31 − 1 -2^{31} <= Node.val <= 2^{31} - 1 −231<=Node.val<=231−1

    方法:广度优先搜索

    解题思路

    广度优先遍历是按层层推进的方式,遍历每一层的节点。广度优先需要用队列作为辅助结构,我们先将根节点放到队列中,然后不断遍历队列。

    首先拿出根节点,如果左子树/右子树不为空,就将他们放入队列中。第一遍处理完后,根节点已经从队列中拿走了,而根节点的两个孩子已放入队列中了,现在队列中就有两个节点 3 和 2。

    第二次处理,会将 3 和 2 这两个节点从队列中拿走,然后再将 3 和 2 的子节点放入队列中,现在队列中就有三个节点 5,3,9。

    我们把每层遍历到的节点的 最大值 都放入到一个结果集中,最后返回这个结果集就可以了。

    代码

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
     *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
     *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
     * };
     */
    class Solution {
    public:
        vector<int> largestValues(TreeNode* root) {
            queue<TreeNode*> que;
            if(root != NULL)    que.push(root);
            vector<int> result;
            while(!que.empty()) {
                int size = que.size();
                int res = -1 * pow(2, 31); 
                for(int i = 0; i < size; i++) {
                    TreeNode* node = que.front();
                    que.pop();
                    res = max(res, node->val);
                    if(node->left != NULL)  que.push(node->left);
                    if(node->right != NULL) que.push(node->right);
                }
                result.push_back(res);
            }
            return result;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32

    复杂度分析

    • 时间复杂度: O ( n ) O(n) O(n)。
    • 空间复杂度: O ( n ) O(n) O(n)。
  • 相关阅读:
    “世界首台USB-C iPhone”被拍卖,目前出价63万人民币
    oracle截取字符串前几位用substr函数如何操作?
    天天写业务代码,我给撸了一个业务处理框架
    计算机视觉之Vision Transformer图像分类
    Java开发之高并发必备篇(五)——线程安全操作之synchronized
    (五)Alian 的 Spring Cloud DB Starter(自己写个starter)
    如何分析和优化慢sql语句
    从小米14安装不上应用说起【适配64位】
    对齐PyTorch,一文详解OneFlow的DataLoader实现
    机械转码日记【14】C++运算符重载的应用——实现一个日期类计算器
  • 原文地址:https://blog.csdn.net/lele_ne/article/details/126450390
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号