【数据结构】建堆的时间复杂度

一.向下调整建堆

1.二叉树层数与总节点个数关系

层数一定时,在二叉树节点个数最大的情况下,二叉树为满二叉树,如下图所示,可以清晰地看到在满二叉树中第h层有2^(h-1)个节点,总节点N就等于一个等比数列的求和,运用等比数列求和公式可以得到:N = 2^h - 1

 

当然还得考虑节点最少的情况,此时第h-1层仍是满节点的,第h层只有一个节点,此时,可以使用上述公式得到h-1层满二叉树总节点为2^(h-1) - 1个,再加上第h层的1个节点,总节点N = 2^(h-1)个

2.单次向下调整的时间复杂度 

 由最终结论可以看出,无论是节点最多还是最少的情况,h与N关系的量级都是logN,同时h可以表示单次向下调整的最大次数-1,那么单次向下调整的时间复杂度就是logN

3.向下调整总次数

在这篇文章里:【数据结构】二叉树-堆_数据结构树可以有三个子树吗-CSDN博客介绍了向下调整算法的思想,就是从最后一个节点的父节点开始依次进行向下调整,直到最后从下标为0的根节点向下调整完毕,那么这个总的调整次数是多少,这同样是能够计算出的。

从最后一个节点的父节点开始向下调整,即从h-1层开始,该层的每个节点向下调整最多调整1次,第h-2层最多调整2次,如此直到第1层需要h-1次,那么每层对应的最多调整次数乘上每层的节点数,就是最多情况下需要的调整次数了。该数列是等差比数列,使用错位相减法可以得出结论,过程如下图所示:

注:最后一层不需要调整(调整次数为0),故不需要考虑是否是满二叉树的情况,该式子都成立 

4.时间复杂度O(N)

注意,时间复杂度不能仅是简单的N个数据乘以单次向下调整的时间复杂度为(N*logN),这是错误的,必须列出具体的关系式再来看。

时间复杂度看的是最坏情况,此时每个节点的调整次数都是最大。时间复杂度是数据个数(N)和执行次数(T)之间的关系,那么此时用已知的两个结论(二叉树层数与总结点关系的结论),用层数(h)为桥梁建立起T与N的关系为如下,时间复杂度舍小取大,N层级大于logN,取N,则时间复杂度为O(N)

二.向上调整建堆O(N*logN)

明白了向下调整建堆,那么向上调整建堆就很容易了,与向下调整同理,不过得出的结果是向上调整算法的时间复杂度为O(N*logN),远远大于向下调整的O(N),其实这很容易看出,向上调整时越往下调整次数越多,同时越往下每层的节点也越多,多的节点乘以多的调整次数,很显然比不过向下调整的 多节点乘以少的调整次数

下图中使用的是满二叉树时N对应h的结论,其实不管使用哪个N对应h的结论都一样,因为其量级就为logN,最后的结果也是不变的。

​​​​​​​

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

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

相关文章

6.基于SpringBoot的SSMP整合案例-业务层开发

目录 1.业务层标准开发 1.1接口定义 1.2实现类定义 1.3测试类定义 1.4小结: 2.业务层快速开发 2.1使用MyBatisP1us提供有业务层通用接口(ISerivce)与业务层通用实现类(ServiceImpl),t> 接口定义: 实现类定义: 测试类: …

AI绘画Stable Diffusion 超高分辨率扩图教程:ControlNet组件-Tile妙用,增强细节保持构图完整!

大家好,我是向阳 今天给大家分享如何用AI绘画工具Stable Diffusion 的 ControlNet Tile工具应用。ControlNet Tile模型能够在SD绘图过程中,实现高分辨率下实现高清扩图,并且避免出现图像分身现象,以及可以调整SD扩散生产过程噪声…

Linux下安装opencv

本次安装的是 opencv3.4.1&#xff0c;在java里面对应的maven配置是 <dependency><groupId>org.bytedeco.javacpp-presets</groupId><artifactId>opencv</artifactId><version>3.4.1-1.4.1</version> </dependency>安装依赖包…

el-date-picker 开始时间选定后,结束时间不可选择开始时间之前的日期

<el-date-pickerv-model"startTime"name"startTime"value-format"yyyy-MM-dd"type"date"change"activityStartTime"placeholder"请选择开始日期":picker-options"pickerOptions"/> <el-date-p…

python项目实战(二手房屋出租系统)

文章目录 1.系统概述2.技术栈3.系统功能4.核心代码分析5. 代码实现6.实现细节6.未来改进方向 在当今数字化时代&#xff0c;自动化和数字化管理工具对于提高效率至关重要。在这篇博客中&#xff0c;我们将一起探索如何使用Python编程语言来创建一个简单的二手房屋出租管理系统。…

Unity射击游戏开发教程:(29)躲避敌人的子弹射击

在这篇文章中,我将介绍如何创建一个可以使玩家火力无效的敌人。创建的行为如下...... 当玩家向敌人开火时,敌人会向左或向右移动。向左或向右的移动是随机选择的,并在一段时间后停止敌人的移动。如果敌人移出屏幕,它就会绕到另一边。将一个精灵拖到画布上,将其缩小以匹配游…

代码随想录-二叉搜索树①

目录 二叉搜索树的定义 700. 二叉搜索树中的搜索 题目描述&#xff1a; 输入输出示例&#xff1a; 思路和想法&#xff1a; 98. 验证二叉搜索树 题目描述&#xff1a; 输入输出示例&#xff1a; 思路和想法&#xff1a; 530. 二叉搜索树的最小绝对差 题目描述&#x…

几个好用json数据处理工具地址

一、在线JSON转SQL工具 在线JSON转SQL - BTool在线工具软件&#xff0c;为开发者提供方便。 二、免费在线 Excel 到 SQL 转换器 免费在线 Excel 到 SQL 转换器 - bfotool 三、json格式化 JSON在线 | JSON解析格式化—SO JSON在线工具 四、json转实体类 在线JSON转C#实体类&…

python实现支付宝异步回调验签

说明 python实现支付宝异步回调验签&#xff0c;示例中使用Django框架。 此方案使用了支付宝的pythonSDK&#xff0c;请一定装最新版本的&#xff0c;支付宝官网文档不知道多久没更新了&#xff0c;之前的版本pip安装会报一些c库不存在的错误&#xff1b; pip install alipay-…

Nature:使用语义熵检测大语言模型中的幻觉

使用语义熵检测大语言模型中的幻觉 Detecting hallucinations in large language models using semantic entropy 论文阅读摘要研究目标论文图表概述总结关键解决方案语义熵计算:虚构内容检测: 双向蕴涵在大语言模型中的应用上下文的重要性蕴涵估计器 实验设计语义熵计算步骤结…

C++ 实现学生成绩管理系统

C 实现学生成绩管理系统 思路&#xff1a; 定义 Student 类&#xff0c;包含学生的基本信息和成绩。实现添加学生、删除学生、修改成绩、显示所有学生成绩和查找学生的功能。使用向量&#xff08;vector&#xff09;存储学生信息。 #include <iostream> #include <…

Docker Compose 安装以及命令的详细解析

Docker Compose 是一种用于定义和运行多容器Docker应用程序的工具。通过Compose&#xff0c;可以使用YAML文件来配置应用程序所需的所有服务&#xff0c;然后使用单个命令创建并启动所有服务。Docker Compose 提供了一种高效、简洁的方式来管理Docker容器和服务&#xff0c;使得…

文献解读-基准与方法研究-第十五期|《不同 DNA 测序平台的标准化比较》

关键词&#xff1a;基准与方法研究&#xff1b;基因测序&#xff1b;结构变异检测&#xff1b; 文献简介 标题&#xff08;英文&#xff09;&#xff1a;Standardized Comparison of Different DNA Sequencing Platforms标题&#xff08;中文&#xff09;&#xff1a;不同 DNA…

CSS Border(边框)

CSS Border(边框) 引言 在网页设计中&#xff0c;边框是增强元素视觉效果和页面布局的重要工具。CSS 提供了丰富的边框样式属性&#xff0c;允许开发者自定义边框的宽度、颜色、样式等。本文将详细介绍 CSS 边框的相关属性&#xff0c;包括基本用法和高级技巧&#xff0c;帮助…

【规范】Git分支管理,看看我司是咋整的

前言 &#x1f34a;缘由 Git分支管理好&#xff0c;走到哪里都是宝 &#x1f3c0;事情起因&#xff1a; 最近翻看博客中小伙伴评论时&#xff0c;发现文章【规范】看看人家Git提交描述&#xff0c;那叫一个规矩一条回复&#xff1a; 本狗亲测在我司中使用规范的好处&#xf…

windows电脑如何使用计划任务定时重启电脑

下面是亲测可用。 1.windows设置-搜索控制面板-系统和安全-管理工具–计划任务 这时候开始创建计划任务了 1.创建基本任务 2.填写名称&#xff08;这里根据需要自己填写&#xff09; 2.触发器里选择&#xff1a;每日&#xff0c;下一步 3.修改时间&#xff0c;然后点击下…

解密智慧校园学工管理系统的学生机构功能

智慧校园学工管理系统中的“学生机构”功能&#xff0c;是专为促进学生组织高效运作和校园文化繁荣而设计的一套数字化管理工具。它从多个维度出发&#xff0c;全面覆盖学生组织的生命周期管理&#xff0c;确保学生自治能力和校园活力得到显著提升。 首先&#xff0c;这一功能支…

【0291】Postgres内核之dynahash源码实现(1)

0. 新建 dynahash(dynamic hash table) Postgres内核中创建一个新的动态哈希表是由函数:hash_create() 完成。 该函数声明于 hsearch.h头文件中,其原型如下: extern HTAB *hash_create(const char *tabname, long nelem,HASHCTL *info, int flags);函数功能:创建一个新…

构造函数深入理解

目录 构造函数构造函数体赋值初始化列表初始化列表格式初始化列表的意义以及注意点const修饰的成员变量初始化对象成员具体初始化的地方缺省值存在的意义例子1例子2 初始化与赋值引用成员变量的初始化注意点1注意点2我的疑惑 自定义类型成员初始化例子1例子2例子3例子4 初始化列…

平衡二叉查找树和多路查找树

平衡二叉查找树 普通平衡二叉查找树 平衡二叉树定义是按照有序排列成树状&#xff0c;左子树数据大于右子树&#xff0c;任意节点的左右子树高度不能大于1 优点&#xff1a;可以保证绝对的平衡 缺点&#xff1a;当进行删除节点和新增节点&#xff0c;树进行自平衡的时候&…