【Leetcode -637.二叉树的层平均值 -671.二叉树中第二小的节点】

news2024/12/23 1:13:04

Leetcode

  • Leetcode -637.二叉树的层平均值
  • Leetcode -671.二叉树中第二小的节点

Leetcode -637.二叉树的层平均值

题目:给定一个非空二叉树的根节点 root , 以数组的形式返回每一层节点的平均值。与实际答案相差 10^(- 5) 以内的答案可以被接受。

示例 1:
在这里插入图片描述
输入:root = [3, 9, 20, null, null, 15, 7]
输出:[3.00000, 14.50000, 11.00000]
解释:第 0 层的平均值为 3, 第 1 层的平均值为 14.5, 第 2 层的平均值为 11 。
因此返回[3, 14.5, 11] 。

示例 2:
在这里插入图片描述

输入:root = [3, 9, 20, 15, 7]
输出:[3.00000, 14.50000, 11.00000]

提示:
树中节点数量在 [1, 104] 范围内

  • 2^31 <= Node.val <= 2^31 - 1

思路:一共要创建三个数组,SumVal 数组记录每一层的节点的和;CountLevels 数组记录每一层的节点数;ret 数组记录每一层的平均值,即利用前两个数组计算后放到 ret 数组中,最后返回;

		void dfs(struct TreeNode* root, double* SumVal, int* CountLevels, int level, int* posSumSize, int* posCountSize)
		{
		    if (root == NULL)
		        return;
		
		    // level 是记录当前节点所在的层数
		    if (level < *posSumSize)
		    {
		        SumVal[level] += (double)root->val;
		        CountLevels[level] += 1;
		    }
		
		    //每次递归到新的一层,就会将最左边的节点的值累加到下标为 posSumSize 位置的 SumVal 数组中
		    //并将 CountLevels 数组中下标为 posCountSize 的位置置1
		    else
		    {
		        SumVal[(*posSumSize)++] = (double)root->val;
		        CountLevels[(*posCountSize)++] = 1;
		    }
		    
		    //递归其左子树和右子树,层数加一
		    dfs(root->left, SumVal, CountLevels, level + 1, posSumSize, posCountSize);
		    dfs(root->right, SumVal, CountLevels, level + 1, posSumSize, posCountSize);
		
		}
		
		double* averageOfLevels(struct TreeNode* root, int* returnSize)
		{
		    //SumVal 数组存放每一层的节点和;CountLevels 数组存放每一层的节点数
		    double* SumVal = (double*)malloc(sizeof(double) * 10000);
		    int* CountLevels = (int*)malloc(sizeof(int) * 10000);
		
		    //posSumSize 和 posCountSize 分别记录两个数组的长度
		    int posSumSize = 0, posCountSize = 0;
		
		    //深度优先搜索
		    dfs(root, SumVal, CountLevels, 0, &posSumSize, &posCountSize);
		
		    //返回数组的长度
		    *returnSize = posSumSize;
		
		    //ret 数组存放每一层的平均值
		    double* ret = (double*)malloc(sizeof(double) * posSumSize);
		    for (int i = 0; i < posSumSize; i++)
		    {
		        ret[i] = SumVal[i] / CountLevels[i];
		    }
		
		    return ret;
		}

Leetcode -671.二叉树中第二小的节点

题目:给定一个非空特殊的二叉树,每个节点都是正数,并且每个节点的子节点数量只能为 2 或 0。如果一个节点有两个子节点的话,那么该节点的值等于两个子节点中较小的一个。

更正式地说,即 root.val = min(root.left.val, root.right.val) 总成立。
给出这样的一个二叉树,你需要输出所有节点中的 第二小的值 。
如果第二小的值不存在的话,输出 - 1 。

示例 1:
在这里插入图片描述

输入:root = [2, 2, 5, null, null, 5, 7]
输出:5
解释:最小的值是 2 ,第二小的值是 5 。

示例 2:
在这里插入图片描述

输入:root = [2, 2, 2]
输出: - 1
解释:最小的值是 2, 但是不存在第二小的值。

提示:
树中节点数目在范围[1, 25] 内
1 <= Node.val <= 2^31 - 1
对于树中每个节点 root.val == min(root.left.val, root.right.val)

思路:因为树中的每个节点都满足 root.val == min(root.left.val, root.right.val);所以根节点就是最小的节点,我们即需要找到比根节点大的节点中最小的节点就是树中第二小的节点;

		void dfs(struct TreeNode* root, int* ret, int rootval)
		{
		    if (root == NULL)
		        return;
		
		    //如果 ret 已被更改,且当前节点的值大于当前 ret 的值,就返回
		    //因为 ret 要找的是比根节点大的值中最小的值
		    if (*ret != -1 && root->val >= *ret)
		        return;
		
		    // rootval 是根节点的值,根节点就是最小的值,找出比它大的数中最小的那个即可
		    // 如果节点的值比当前 ret 大,会在上面直接返回
		    if (root->val > rootval)
		        *ret = root->val;
		
		    //递归其左子树和右子树
		    dfs(root->left, ret, rootval);
		    dfs(root->right, ret, rootval);
		}
		
		int findSecondMinimumValue(struct TreeNode* root)
		{
		    //返回值初始化为 -1
		    int ret = -1;
		    dfs(root, &ret, root->val);
		    return ret;
		}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/689157.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TCP服务器的C#实现

1、TCP实现类 internal class TcpServer{public Socket ServerSocket { get; set; }public Dictionary<string,Socket> Sockets { get; set; } new Dictionary<string,Socket>();public byte[] SendBuffer { get; set; }public byte[] ReceiveBuffer { get; set; …

Qt消息对话框

一、头文件及类型 #include<QMessageBox> 二、错误、信息、提示、警告演示 错误对话框 QMessageBox::critical(this,"critical","错误"); 信息对话框 QMessageBox::information(this,"info","信息"); 提问对话框 if(QMessageBo…

发布自己的第一个抖音小程序

结构与微信小程序一样 内嵌H5网页&#xff0c;适用于任何平台&#xff0c;同样也是使用web-view组件 <web-view src"https://some-domain/some/path"></web-view> 相比起来&#xff0c;它比微信小程序更加简化&#xff0c;开发会更方便了。 API查询地…

超越Java 7,迎接Java 8时代!掌握这些新特性提升你的编程技能!

大家好&#xff0c;我是小米&#xff0c;一个热衷于技术分享的小伙伴。今天&#xff0c;我将向大家介绍Java 8中的一些新特性。Java 8作为一次重大更新&#xff0c;引入了许多令人激动的新功能&#xff0c;让我们的编码变得更加简洁高效。接下来&#xff0c;我们将详细介绍这些…

【暂时解决】radio单选框的change事件执行两次

项目场景&#xff1a; 简单的单选框场景 选择国内地区&#xff0c;省市县的下拉框就显示&#xff0c;选择国外地区就隐藏。 问题描述 当我使用radio的change事件时&#xff0c;会执行两次 javascript&#xff1a; $(input[typeradio][nameoptionsRadios]).change(function …

黑产科普丨揭秘游戏黑灰产业链

自今年起&#xff0c;游戏版号已恢复常态化发放&#xff0c;游戏行业在官方发文肯定、重获资本青睐、AI降本增效等多方助力下持续回暖。暑期档将至&#xff0c;游戏厂商为了抢占更多的市场份额&#xff0c;占据更多的玩家视野&#xff0c;将有大量的游戏选择在这个时间上线。 …

datax-Oracle新增writeMode支持

1.在com.alibaba.datax.plugin.writer.oraclewriter.OracleWriter中注释此内容,以让oracle支持writeMode模式 2.在com.alibaba.datax.plugin.rdbms.writer.util.WriterUtil中,增加对oracle的判断,将getWriteTemplate修改为如下内容 public static String getWriteTemplate(List…

在文件夹中获取某个文件的绝对路径

#!/bin/bash -lpathfind $(pwd) -name *.ipaecho ${path}写成下面这样也是可以的 path$(find $(pwd) -name *.ipa)如图所示&#xff0c;Export 文件夹下有.ipa文件&#xff0c;我们目前想获取.ipa文件的绝对路径 执行结果如下 192:Jenkins liubo$ cd /Users/liubo/Desktop/…

C# 通过委托实现多个窗口之间的传值

之前用qt写的时候&#xff0c;都有信号和槽来实现&#xff0c;用C#的话应该也有类似的 大概实现的是我在父窗口当中new了两个子窗口&#xff0c;这个两个子窗口都可以将处理完的数据传递给父窗口&#xff0c;并且两个子窗口通过父窗口进行通信。 我这就按上面窗口名称来说明代…

pipeline实现二次还原

通过mode参数确定是否发布还是回滚&#xff0c;在满足rollback条件下&#xff0c;列举出我们的所有的备份的目录&#xff0c;根据回滚条件选择索要回滚的目录(目录是根据时间戳来判断创建的文件) pipeline {agent anyparameters {choice(name: mode, choices: [deploy,rollbac…

HA 自动化-通知提醒

配置->场景自动化->创建自动化 notify.notify

Gitlab群组及项目仓库搭建

1、新建群组 2、新建项目 3、克隆到Visualstudio 复制克隆地址&#xff0c;克隆到本地 这里会让你登录账号 可以添加成员并邀请ta进项目组 从已注册用户列表中选择 4、Git工作流 回顾一下Git工作流&#xff0c;工程人员只需要从Develop分支新建自己的分支即可。分支命名以姓名…

设计模式学习之抽象工厂模式

设计模式系列往期文章 设计模式学习之策略模式设计模式学习之策略模式在前端的应用设计模式学习之简单工厂模式设计模式学习之工厂方法模式 如果你已经理解了工厂方法模式&#xff0c;那你能够很快的明白抽象工厂模式。 温习&#xff1a;什么是工厂方法模式 我们先温习一下…

【面试题19】B-Tree和B+Tree的区别,以及B+Tree在MySQL中的应用

文章目录 一、前言二、关于B-Tree和B Tree2.1 B-Tree2.2 BTree 三、B Tree与B Tree的差异3.1 叶子节点的差异3.2 数据访问的差异3.3 范围查询的差异 四、Mysql中BTree的应用场景4.1 主键索引4.2 唯一索引4.3 普通索引 五、MySQL为什么使用BTree来做索引&#xff1f;总结 一、前…

【网络安全】IP地址定位技术的应用场景

随着科技的不断发展&#xff0c;网络空间已经成为人们生活中重要的一部分。而其中&#xff0c;IP地址定位技术又是网络空间不可或缺的一部分。IP地址定位技术是一种可以根据IP地址确定用户位置的技术这项技术不仅可以用于个人定位&#xff0c;也可以使用在商业领域、网络安全和…

【新星计划·2023】认识和学习BASH(一)

作者&#xff1a;Insist-- 个人主页&#xff1a;insist--个人主页 作者会持续更新网络知识和python基础知识&#xff0c;期待你的关注 目录 一、认识BASH 1、硬件、核心与Shell ①硬件 ②核心管理 ③应用程序 2、为何要学文字接口的shell&#xff1f; 3、系统的合法shel…

学习AQS

面试的时候被问到AQS会不会一脸懵逼呢?今天来学习一下AQS吧! 看看这个听起来高大上又难以回答的东西到底是个啥? 1.什么是AQS JUC包中 的很多同步器如ReentrantLock、Semaphore、CountDownLatch等等都是有一些基础的共同的行为,比如:等待队列、条件队列、独占获取、共享…

IntelliJ IDEA - IDEA 如何快速生成 serialVersionUID?

问题描述 今天遇到序列化问题的时候&#xff0c;需要用到 serialVersionUID 字段&#xff0c;如下。但是不知道如何快速自动生成这个&#xff0c;于是有了这篇博客&#xff0c;哈哈哈 private static final long serialVersionUID 6828716364537510652L; 解决方案 首先如图…

STM32F系列项目定时器配置-中断触发源详解

1.以高级定时器为例&#xff1a; 2.触发源选择与极性选择&#xff1a; 3.触发源介绍 (282条消息) 【STM32技巧】&#xff08;1&#xff09;STM32定时器8种触发源之ITR0~ITR3说明_stm32 定时器触发定时器_小石头有大内涵的博客-CSDN博客 ITR0内部触发0ITR1内部触发1ITR2内部触…

为什么ECB模式不安全\链接模式【密码学】(6)

目录 一、链接模式 二、ECB模式 三、链接模式缺失带来什么问题 一、链接模式 之前讲过&#xff0c;链接模式就是将是一个分组运算和下一个分组运算联系起来。 上一个分组运算的所有结果都有可能参与到下一个分组运算中&#xff1b;下一个分组运算的每一个要素&#xff0c…