当前位置: 首页 > news >正文

“树”的高度的计算——CSP-J1真题详解

如同树有高度一样,数据结构中的“树”也有高度,只不过这个高度指的是第几“层”。就像武功可以修炼到第几层一样,树也可以长到第几层。

需要指明的是,树的根节点属于第几层是没有严格的定义的,一般被认为是处于第0层或第1层(国内主流视为第1层)。

以树的根节点为第1层为例,由树根长出来的分支就是第2层,分支再长出来的是第3层,以此类推。只不过,一般来讲数据结构中的“数”一般都被设计成倒着长的树。

明白了树的高度是什么,就可以做个真题练练手。

【题目】根节点的高度为1,一棵拥有2023个节点的三叉树高度至少为()

A. 6

B. 7

C. 8

D. 9

【题目来源】

2023 CCF非专业级别软件能力认证第一轮 (CSP-J1) 入门级C++语言试题 第5题

【解析】

本题先是明确告诉你“根节点的高度为1”,也就是说将树的根节点视为第1层。如果没有这句话,题目就是不严谨的。

三叉树就是一个树枝最多可以长出三个树杈的树,就像计划生育一户最多可生三个娃一样。已知节点数(2023个),求树的最小高度,也就是树至少要长多少层,或者可以看作人要繁衍多少辈。显然,生的越多,所需的层数就越少。所以,这个问题就相当于问:一户人家,每辈生三个娃,生出2023个娃需要多少辈?

这就是一个画图找规律的题:

很容易看出,每一层的节点数都是前一层的3倍。

第一层:1

第二层:3=1×3

第三层:9=3×3

第四层:27=9×3

第五层:81=27×3

第六层:243=81×3

第七层:729=243×3

第八层:2187=729×3

前七层的节点为1093(1+3+9+27+81+243+729=1093),无论怎样努力也生不出2023个娃;第八层的节点为3280(1093+2187=3280),大于2023。所以要生出2023个娃,至少要八代,即一棵拥有2023个节点的三叉树高度至少为8,本题选C。

实质上,这些节点数构成的正是高中要学的等比数列(后一项与前一项的比值相等)。求n层的节点就是求等比数列前n项的和,公式为:

s = a1*(1-q^n)/(1-q)

公式中的a1为首项,q就是后一项与前一项的比值,被称为公比。了解了这个公式,不管是几叉树都可以套公式算出n层的总节点数。本题为三叉树,公比为3,代入得:

s = 1*(1-3^n)/(1-3) = (3^n-1)/2

但是,背熟公式未必是快速解题的最佳方式,比如本题,当n取7、8等相对较大的值时,因为同时有乘方、减法、除法,算出s的值并不那么方便。

相反,按照前面那样一层一层推导,每次都乘一个很小3,计算量小,反而是更快的。在求总节点数时,也不必从第一层一直加到最后一层,可以采用估算的方式,很快就能锁定答案。方法就是在算每一层的节点数时,心里都要有一杆秤:暗暗与目标数2023进行对比。显然计算到第六层时,只有一个数上百,加起来根本不可能上千,别说2000多了,所以根本不用算就能直接排除。算到第七层,简单估算下,六、七两层加起来还不到一千,加上前面的虾兵蟹将也根本不可能破2000,所以肯定也不行。算到第八层,好嘛,您老人家一层已经超过2023了,所以答案是什么还用问吗?

因为求树高度的题目很少见,所以咱们只要掌握这种找规律的方法就可以从容应对了。

但是,如果你是个追求极致的人,还想让速度更快怎么办呢?

吴军曾提出过:真正的高手都是“杀鸡要用牛刀”的人!

这时候你还得用公式,但是咱们说过公式存在计算困难的问题,怎么解决?

无他,唯手熟尔!

方法就是把计算结果提前背下,就像背九九乘法表一样。

提高速度最有效的办法就是减少步骤。记公式是为了减少推导步骤,记结果是为了减少计算步骤。

速度拼到最后拼的是记忆。

以二叉树和三叉树举例,每层节点数和节点总数如下:

n

二叉树

三叉树

单层节点

总节点

单层节点

总节点

2^(n-1)

2^n-1

3^(n-1)

(3^n-1)/2

1

1

1

1

1

2

2

3

3

4

3

4

7

9

13

4

8

15

27

40

5

16

31

81

121

6

32

63

243

364

7

64

127

729

1093

8

128

255

2187

3280

9

256

511

6561

9841

10

512

1023

19683

29524

当然要记住这个表很困难,性价比也比较低。但如果改成记下面这个表,再结合公式辅助,完全可以做到秒解。

n

2^n

3^n

1

2

3

2

4

9

3

8

27

4

16

81

5

32

243

6

64

729

7

128

2187

8

256

6561

9

512

19683

10

1024

59049

记这个表就比较有意义了,尤其是2^n在二进制运算中很常用,所以记住它性价比就很高。虽然记3^n性价比没2^n高,但总比记π的小数点后n位更实用吧!

相关文章:

“树”的高度的计算——CSP-J1真题详解

如同树有高度一样,数据结构中的“树”也有高度,只不过这个高度指的是第几“层”。就像武功可以修炼到第几层一样,树也可以长到第几层。 需要指明的是,树的根节点属于第几层是没有严格的定义的,一般被认为是处于第0层或…...

Docker介绍、docker安装以及实现docker的远程管理

1.Docker介绍 1.Docker介绍 Docker 是⼀个开源的应用容器引擎,可以实现虚拟化,完全采用“沙盒”机制,容器之间不会存在任何接口。 Docker 通过 Linux Container(容器)技术将任意类型的应用进行包装,变成一…...

【UE5】基于摄像机距离逐渐剔除角色

效果 步骤 1. 新建一个工程,在内容浏览器中添加第三人称游戏内容包 2. 找到第三人称角色的材质实例“MI_Quinn_01”并打开 找到材质实例的父项材质“M_Mannequin” 打开材质“M_Mannequin” 在材质图表中添加如下节点 此时运行效果如文章开头所示。 参考视频&#…...

LabVIEW优化内存使用

在LabVIEW中,优化内存使用的关键在于理解LabVIEW的内存管理机制并采用一些最佳实践。以下是一些可能帮助减少内存占用的方法: 1. 减少数据副本的生成 避免不必要的数据复制:每当你在程序中传递数组或子数组时,LabVIEW可能会创建副…...

多进程和多线程基础概念LINUX

进程和程序的区别 程序是静态的,它是保存在磁盘上的指令的有序集合,没有任何执行的概念进程是一个动态的概念,它是程序执行的过程,包括了动态创建、调度和销毁的整个过程 并行:在 cpu 多核的支持下,实现物…...

React Native的Android端fetch的网络请求FormData请求错误:TypeError:Network request failed

// formdataconst formData new FormData();formData.append("code", appUserCode);formData.append("wallet", appName);// const formDataStr code appUserCode &wallet appName;// 参数形式//const _body code${appUserCode}&wallet${app…...

python之matplotlib (1 介绍及基本用法)

介绍 matplotlib是Python中的一个绘图库,它提供了一个类似于 MATLAB 的绘图系统。使用matplotlib你可以生成图表、直方图、功率谱、条形图、错误图、散点图等。matplotlib广泛用于数据可视化领域,是 Python 中最著名的绘图库之一。 同样matplotlib的安…...

ROS2常用指令

ROS2(Robot Operating System 2)是一个用于机器人软件开发的灵活框架,它提供了一套丰富的工具和库来支持机器人的开发、模拟、部署和测试。ROS2的常用指令可以大致分为几个类别,包括功能包管理、节点管理、话题管理、服务管理、动…...

SQL注入(原理、分类、union、POST注入)

目录 【学习目标、重难点知识】 【学习目标】 【重难点知识】 SQL注入简介 SQL注入原理 SQL注入类型 MySQL与SQL注入的相关知识 information_schema 数据库的结构 数据库查询语句 limit的用法 需要记住的几个函数 注释符号 SQL注入探测方法 SQL注入漏洞攻击流程…...

【勒索病毒应急响应流程】

概述 不同应急事件响应方式不同,建议大家阅读以下案例,解决自己当前的困扰,当然也可以根据自己的经验对文章进行补充和修正,欢迎在评论区留言。 案例1 事件概述 某安服团队接到某政府部门的远程应急响应求助,要求对被勒索服务器进行排查分析并溯源。 排查溯源 1、应…...

C ++初阶:C++入门级知识点

目录 🌞0.前言 🚈1.C输入输出 🚈2.缺省参数 🚝2.1全缺省参数 🚝2.2半缺省参数 🚈3.函数重载 🚝3.1参数类型不同 🚝 3.2参数个数不同 🚝3.3参数类型顺序不同 ​…...

php中如何高效地实现一个函数以判断给定日期是否位于多个预定义的时间范围内,同时确保代码的可读性、可维护性和性能优化

背景信息: 我有一个包含多个时间范围的数组,每个时间范围由起始日期和结束日期组成(目前以字符串形式给出),例如: $ranges [[start > 2023-01-01, end > 2023-03-31],[start > 2023-06-01, end …...

存在重复元素 II(LeetCode)

题目 给你一个整数数组 nums 和一个整数 k &#xff0c;判断数组中是否存在两个 不同的索引 i 和 j &#xff0c;满足 nums[i] nums[j] 且 abs(i - j) < k 。如果存在&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 解题 """ 时间复杂度…...

认知杂谈21

今天分享 有人说的一段争议性的话 I I 自在之“坏”&#xff1a;真实自我的绽放 在社交场合中&#xff0c;听到“他不是个好人”这句话可能会让人惊讶&#xff0c;但其实被贴上“坏人”标签的人往往敢于跳出规则框架&#xff0c;展现真实自我。他们不做表面和谐的牺牲品&am…...

2024前端面试题-工程化篇

1.webpack&#xff08;模块打包工具&#xff09;五大核心 Entry入口&#xff0c;Output定义输出路径和命名规则&#xff0c;Loader模块转换器&#xff0c;Plugin扩展插件&#xff0c;Mode模式&#xff08;Webpack使用相应模式的配置&#xff09; 2.谈一谈你对Loader和Plugin的…...

【附源码】Python :PYQT界面点击按钮随机变色

系列文章目录 Python 界面学习&#xff1a;PYQT界面点击按钮随机变色 文章目录 系列文章目录一、项目需求二、源代码三、代码分析3.1 导入模块&#xff1a;3.2 定义App类&#xff1a;3.3 构造函数&#xff1a;3.4 初始化用户界面&#xff1a;3.5 设置窗口属性&#xff1a;3.6 …...

[Qt][QSS][下]详细讲解

目录 1.样式属性0.前言1.盒模型(Box Model) 2.常用控件样式属性1.按钮2.复选框3.单选框4.输入框5.列表6.菜单栏7.注意 1.样式属性 0.前言 QSS中的样式属性⾮常多&#xff0c;不需要都记住&#xff0c;核⼼原则是⽤到了就去查 ⼤部分的属性和CSS是⾮常相似的 QSS中有些属性&am…...

RAII在实现webserver这个项目中是怎么体现的?起到了什么作用

在WebServer项目中&#xff0c;RAII&#xff08;Resource Acquisition Is Initialization&#xff0c;即资源获取即初始化&#xff09;是一种重要的资源管理策略&#xff0c;它主要通过智能指针、锁、文件句柄等对象的生命周期来管理资源的分配和释放。RAII在WebServer项目中的…...

QT下显示自己派生的QWidget界面(提升为)

在实际开发过程中&#xff0c;我们可能有这样的需求&#xff0c;自己绘制一个仪表盘界面&#xff0c;然后将其贴到主界面上方。 这个时候就会用到“提升为”这个功能&#xff0c;该功能目的是将QWidget提升为自己派生的QWdiget子类&#xff0c;具体操作为&#xff0c;在主界面…...

jvm监控工具一览

下面是对 BTrace、JAD、JMAP、JSTAT、JSTACK、JINFO 以及 MARK 工具的比较表&#xff1a; 工具/属性功能适用场景使用难度是否侵入式是否需要重启 JVMBTrace动态跟踪和监控 Java 应用程序性能分析、故障排查、日志收集、安全监控中等无侵入式否JAD反编译 Java 字节码文件&…...

51单片机GPIO控制实战:手把手教你玩转P0-P3端口

51单片机GPIO深度实战&#xff1a;从端口特性到高级控制技巧 当你第一次点亮LED时&#xff0c;那种成就感就像打开了嵌入式世界的大门。但真正掌握51单片机的GPIO&#xff0c;远不止让灯闪烁那么简单。P0-P3这四个看似简单的端口&#xff0c;藏着许多工程师多年积累的实战经验。…...

别再手动整理会议纪要了!用Dify+FunAudioLLM+DeepSeek,一键生成带格式的Word文档

职场效率革命&#xff1a;三分钟将会议录音转为专业纪要的智能方案 每次会议结束后&#xff0c;行政助理小林总要花两小时反复听录音、整理重点&#xff0c;直到凌晨才能发出会议纪要。这种场景在无数企业重复上演——据调研机构数据&#xff0c;职场人平均每周耗费4.7小时在会…...

openpilot深度解析:开源自动驾驶系统的架构设计与实战应用

openpilot深度解析&#xff1a;开源自动驾驶系统的架构设计与实战应用 【免费下载链接】openpilot openpilot is an operating system for robotics. Currently, it upgrades the driver assistance system on 300 supported cars. 项目地址: https://gitcode.com/GitHub_Tre…...

MySQL 存储过程中字符集不匹配导致查询性能下降的解决方案

本文详解 MySQL 存储过程中因 COLLATE 显式指定与列实际字符集/排序规则不兼容&#xff0c;导致索引失效、查询变慢的根本原因&#xff0c;并提供可落地的字符集统一策略、SQL 优化写法及验证方法。 本文详解 mysql 存储过程中因 collate 显式指定与列实际字符集/排序规则…...

Qwen3-TTS功能体验:除了文本转语音,还能用自然语言微调音色

Qwen3-TTS功能体验&#xff1a;除了文本转语音&#xff0c;还能用自然语言微调音色 1. 引言&#xff1a;重新定义语音合成的可能性 想象一下&#xff0c;你正在为一个游戏角色配音&#xff0c;需要一种"低沉沙哑的中年男性声音&#xff0c;带着些许疲惫和沧桑感"。…...

类器官:十五五规划下的“人体替身“革命

3月10日&#xff0c;《中华人民共和国国民经济和社会发展第十五个五年规划纲要&#xff08;草案&#xff09;》正式对外公布并提请全国人大审议。值得关注的是&#xff0c;类器官与器官芯片技术首次被提升至国家战略高度——在"专栏8 前沿科技攻关"的"生命科学与…...

语义网络表示法:从节点、关系到继承推理

在知识表示的发展过程中&#xff0c;语义网络表示法&#xff08;Semantic Network Representation&#xff09;是一种非常重要的方法。它用“节点—关系—节点”的结构来表示知识&#xff0c;把对象及其联系组织成有向图&#xff0c;因此比单纯的逻辑公式更直观&#xff0c;也更…...

ICPC竞赛中的字符串优化技巧:以香港站K题LR String为例,详解预处理与加速查询

ICPC竞赛中的字符串优化技巧&#xff1a;以香港站K题LR String为例&#xff0c;详解预处理与加速查询 在算法竞赛的战场上&#xff0c;字符串处理往往是决定胜负的关键分水岭。当其他选手还在为TLE&#xff08;Time Limit Exceeded&#xff09;焦头烂额时&#xff0c;掌握预处…...

Qwen3-14B私有部署镜像实测:一键启动,打造你的私有AI大脑

Qwen3-14B私有部署镜像实测&#xff1a;一键启动&#xff0c;打造你的私有AI大脑 1. 开箱即用的私有AI解决方案 在当今AI技术快速发展的背景下&#xff0c;越来越多的企业和开发者希望拥有自己的私有AI模型。Qwen3-14B私有部署镜像正是为这一需求而生的解决方案。它基于强大的…...

【现代通信技术】SDH技术:从PDH到SDH的演进与核心优势解析

1. 从电缆时代到光纤革命&#xff1a;PDH与SDH的技术分野 记得刚入行那会儿&#xff0c;师傅带着我维护老式通信设备&#xff0c;成捆的电缆像蜘蛛网般盘踞在机房。那时候的准同步数字体系&#xff08;PDH&#xff09;就像用不同方言交流的邻居——北美用E1&#xff08;1.544Mb…...