(二叉树遍历)leetcode515. 在每个树行中找最大值

该文介绍了如何解决LeetCode上的一个问题,即给定一棵二叉树,找出每层的最大值。方法是采用层序遍历,利用C++的LinkedList作为队列,每次处理一层的节点并记录最大值。时间复杂度和空间复杂度均为O(n),其中n为树的节点数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、题目

1、题目描述

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

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

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

2、基础框架

  • C++版本给出的基础框架如下:

3、原题链接

https://leetcode.cn/problems/find-largest-value-in-each-tree-row/

二、解题报告

1、思路分析

   ( 1 ) (1) (1)层序遍历,每次将队列一整层的节点取出,将其子节点放入队列中
   ( 2 ) (2) (2)取出节点的时候记录该层的最大值

2、时间复杂度

时间复杂度为O(n),空间复杂度为O(n)

3、代码详解

class Solution {
    public List<Integer> largestValues(TreeNode root) {
        List<Integer> re = new ArrayList<>();
        if (root == null) return re;
        LinkedList<TreeNode> que = new LinkedList<>();
        que.add(root);
        while(que.size() != 0) {
            int n = que.size();
            int max = 0;
            for (int i=0; i < n; i++) {
                TreeNode p = que.getFirst();
                que.remove();
                if (i == 0) max = p.val;
                else max = Math.max(max, p.val);
                if (p.left != null) {
                    que.add(p.left);
                }
                if (p.right != null) {
                    que.add(p.right);
                }
            }
            re.add(max);
        }
        return re;
    }
}

三、本题小知识

1.java队列知识,普通队列用LinkedList,优先队列使用PriorityQueue

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值