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


提示:
- 树中节点数量在
[1, 104]范围内 -231 <= Node.val <= 231 - 1
代码:
/*** 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<double> averageOfLevels(TreeNode* root) {vector<double> res;queue<TreeNode*> DS;int cnt;double sum;if(root == nullptr) return res;DS.push(root);while(!DS.empty()){sum = 0;cnt = DS.size();for(int i = 0; i < cnt; i++){TreeNode* p = DS.front();DS.pop();sum += p->val;if(p->right != nullptr){DS.push(p->right);}if(p->left != nullptr){DS.push(p->left);}}res.push_back(sum / cnt);}return res;}
};
解题思路:
(1)使用广度优先搜索。
(2)一次全部读出一层的节点,并进行计算平均值。
相关文章:
力扣637. 二叉树的层平均值
给定一个非空二叉树的根节点 root , 以数组的形式返回每一层节点的平均值。与实际答案相差 10-5 以内的答案可以被接受。 提示: 树中节点数量在 [1, 104] 范围内-231 < Node.val < 231 - 1 代码: /*** Definition for a binary tree node.* stru…...
【前端】Next.js 服务器端渲染(SSR)与客户端渲染(CSR)的最佳实践
关于Next.js 服务器端渲染(SSR)与客户端渲染(CSR)的实践内容方面,我们按下面几点进行阐述。 1. 原理 服务器端渲染 (SSR): 在服务器上生成完整的HTML页面,然后发送给客户端。这使得用户在首次访问时能够…...
路径规划之启发式算法之一:A-Star(A*)算法
A*算法是一种启发式搜索算法,常用于解决路径规划问题。 一、A*算法的定义与原理 A*算法是一种用于在图形或网格中查找最短路径的算法。它在搜索过程中综合考虑了每个节点的实际距离(g值)和预估距离(h值),以…...
Android复习代码1-4章
public class RudioButton extends AppCompatActivity {Overrideprotected void onCreate(Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_rudio_button);// 找到RadioGroup和TextView的实例RadioGroup radioGrou…...
【问题】webdriver.Chrome()设置参数executable_path报不存在
场景1: 标红报错unresolved reference executable_path 场景2: 执行报错TypeError: __init__() got an unexpected keyword argument executable_path 原因: 上述两种场景是因为selenium4开始不再支持某些初始化参数。比如executable_path 解决: 方案…...
win10系统安装docker-desktop
1、开启Hyper-v ———————————————— Hyper-V 是微软提供的一种虚拟化技术,它允许你在同一台物理计算机上运行多个独立的操作系统实例。这种技术主要用于开发、测试、以及服务器虚拟化等领域。 —————————————————————— &#…...
小程序-基于java+SpringBoot+Vue的乡村研学旅行平台设计与实现
项目运行 1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA; 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.硬件环境:…...
组件A底部栏(position: fixed )事件使用$emit更新内容失败bug解决
今天遇到一个很离奇的bug,记录一下 问题:在组件内底部栏使用$emit触发按钮事件但打印出来的值是初始化的值,更新的值被重置导致更新失败 原因:组件内底部使用了 position: fixed; 固定, 导致组件内插槽 this 与 保存按…...
数据结构——排序第三幕(深究快排(非递归实现)、快排的优化、内省排序,排序总结)超详细!!!!
文章目录 前言一、非递归实现快排二、快排的优化版本三、内省排序四、排序算法复杂度以及稳定性的分析总结 前言 继上一篇博客基于递归的方式学习了快速排序和归并排序 今天我们来深究快速排序,使用栈的数据结构非递归实现快排,优化快排(三路…...
C++的类功能整合
1. 类的基本概念 类是面向对象编程的核心,它封装了数据和操作数据的函数。 #include <iostream> using namespace std;class MyClass { public:int publicData;void publicFunction() {cout << "Public function" << endl;}private:i…...
《String类》
目录 一、定义与概述 二、创建字符串对象 2.1 直接赋值 2.2 使用构造函数 三、字符串的不可变性 四、常用方法 4.1 String对象的比较 4.1.1 比较是否引用同一个对象 4.1.2 boolean equals(Object anObject)方法:按照字典序比较 4.1.3 int compareTo(Strin…...
【docker】docker的起源与容器的由来、docker容器的隔离机制
Docker 的起源与容器的由来 1. 虚拟机的局限:容器的需求萌芽 在 Docker 出现之前,开发和部署软件主要依赖虚拟机(VMs): 虚拟机通过模拟硬件运行操作系统,每个应用程序可以运行在自己的独立环境中。虽然虚…...
Window 安装 Nginx
参考链接 Windows 环境nginx安装使用及目录结构详解_windows 安装nginx-CSDN博客 Nginx 安装及配置教程(Windows)【安装】_nginx下载安装-CSDN博客 安装 1)下载 nginx: download 2)解压 3)启动 3.1)方…...
replace (regexp|substr, newSubstr|function)替换字符串中的指定部分
replace 方法用于替换字符串中的指定部分。它可以接受一个子字符串或正则表达式作为第一个参数,第二个参数是替换的内容。 用法示例 基本替换 let str "Hello, world!"; let newStr str.replace("world", "everyone"); console.lo…...
【ROS2】Ubuntu22.04安装ROS humble
一. ROS简介 1.1 什么是ROS ROS 是一个适用于机器人的开源的元操作系统。它提供了操作系统应有的服务,包括硬件抽象,底层设备控制,常用函数的实现,进程间消息传递,以及包管理。ROS的核心思想就是将机器人的软件功能做…...
cesium 3Dtiles变量
原本有一个变亮的属性luminanceAtZenith,但是新版本的cesium没有这个属性了。于是 let lightColor 3.0result._customShader new this.ffCesium.Cesium.CustomShader({fragmentShaderText:void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial mate…...
配置泛微e9后端开发环境
配置泛微e9的后端开发环境 1.安装jdk1.8(请自行安装并设置环境变量) 2.将服务器上的WEARVER文件夹拷贝到开发环境下(其中要包含ecology和Resin目录) 3.通过idea创建一个基础Java项目,将jdk设置为1.8 4.添加依赖,需要将3个文件夹的所有jar包添加到项目中…...
【Stable Diffusion】安装教程
目录 一、python 安装教程 二、windows cuda安装教程 三、Stable Diffusion下载 四、Stable Diffusion部署(重点) 一、python 安装教程 (1)第一步下载 打开python下载页面,找到python3.10.9,点击右边…...
USB Type-C一线通扩展屏:多场景应用,重塑高效办公与极致娱乐体验
在追求高效与便捷的时代,启明智显USB Type-C一线通扩展屏方案正以其独特的优势,成为众多职场人士、娱乐爱好者和游戏玩家的首选。这款扩展屏不仅具备卓越的性能和广泛的兼容性,更能在多个应用场景中发挥出其独特的价值。 USB2.0显卡ÿ…...
【力扣】541.反转字符串2
问题描述 思路解析 每当字符达到2*k的时候,判断,同时若剩余字符>k,只对前k个进行判断(这是重点)因为字符串是不可变变量,所以将其转化为字符串数组,最后才将结果重新转变为字符串 字符串->字符数组 …...
用MATLAB玩转三维曲面:教你用meshgrid和colormap实现科研级可视化效果
MATLAB三维曲面可视化:从基础绘制到期刊级图表优化 科研图表是学术论文的"门面",一张专业的三维曲面图能让数据规律跃然纸上。作为工程与科学计算领域的标准工具,MATLAB提供了强大的三维可视化能力,但要将原始数据转化为…...
实战指南:基于Windows Server构建企业级AAA认证体系
1. 为什么企业需要AAA认证体系 在企业IT环境中,网络设备管理一直是个头疼的问题。想象一下,公司有几十台交换机、路由器,每个设备都要单独维护账号密码,管理员得记住上百组凭证。更可怕的是,当有员工离职时,…...
手把手教你解决RK3568开发板连接MacBook充电异常(FUSB302 PD2.0实战)
RK3568开发板与MacBook充电异常排查指南:从现象到内核配置的全链路解析 Type-C接口的普及让设备间的电力传输变得前所未有的便捷,但当你将一块RK3568开发板通过C-to-C线缆连接到MacBook时,却发现充电状态极不稳定——电流频繁跳变、连接时断时…...
游戏反外挂系统的检测逻辑 ——一场永不停歇的猫鼠游戏
我在一家游戏公司做了四年反外挂。 入职第一天,主程跟我说了一句话,我到现在都记得:“你不是在写代码,你是在跟人斗。代码是死的,外挂作者是活的。你堵上一个洞,他明天就找到另一个洞。你唯一的优势是你在城里,他在城外。但别忘了,城墙是你砌的,他比你更想知道哪块砖…...
QGIS地图下载避坑指南:如何用XYZ Tiles精准导出0.3米分辨率地图(附CRS设置技巧)
QGIS高精度地图下载实战:从XYZ Tiles配置到0.3米级分辨率输出的完整方案 当城市规划师需要在老旧城区改造项目中获取0.3米精度的底图时,或者测绘工程师要为基础设施项目准备高分辨率参考影像时,QGIS配合XYZ Tiles的解决方案往往能提供专业级的…...
从零玩转MSP430:用CCS 20.1.1实现库函数开发(附Driverlib配置技巧)
从零玩转MSP430:用CCS 20.1.1实现库函数开发(附Driverlib配置技巧) 在嵌入式开发领域,MSP430系列以其超低功耗和丰富外设资源著称,但很多开发者在从寄存器操作转向库函数开发时常常遇到障碍。本文将基于Code Composer …...
Python调用FFmpeg报错127?手把手教你解决libopenh264.so.5缺失问题(附conda安装指南)
Python调用FFmpeg报错127?手把手教你解决libopenh264.so.5缺失问题(附conda安装指南) 当你兴致勃勃地准备用Python调用FFmpeg处理视频时,突然蹦出一个subprocess.CalledProcessError,还带着神秘的退出码127,…...
RT-Thread Studio常见编译错误排查指南
1. RT-Thread Studio编译环境基础问题排查 刚接触RT-Thread Studio的开发者经常会遇到一些基础编译问题,这些问题大多与环境配置或基础语法有关。最常见的就是数据类型定义缺失,比如unknown type name uint8_t这类错误。这通常是因为没有包含标准数据类型…...
宝塔面板降级实战:从安装到屏蔽自动升级的完整指南
宝塔面板降级实战:从安装到屏蔽自动升级的完整指南 在服务器管理领域,宝塔面板以其直观的图形化界面和丰富的功能模块,成为众多运维人员的首选工具。然而,随着版本迭代,部分用户发现新版本可能存在兼容性问题、强制绑定…...
重构浏览器自动化:Midscene Chrome扩展如何颠覆重复操作困境
重构浏览器自动化:Midscene Chrome扩展如何颠覆重复操作困境 【免费下载链接】midscene Let AI be your browser operator. 项目地址: https://gitcode.com/GitHub_Trending/mid/midscene 每天重复执行同样的浏览器操作?填写表单、数据抓取、页面…...
