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

堆、优先队列、堆排序

堆:

定义:

必须是一个完全二叉树(完全二叉树:完全二叉树只允许最后一行不为满,且最后一行必须从左往右排序,最后一行元素之间不可以有间隔)

 堆序性:

大根堆:每个父节点元素都要大于子节点元素

小根堆:每个父节点元素都要小于子节点元素

 堆的存储:

首先按照层序遍历的顺序来给结点编号(从上到下从左到右)把这些编号对应到一个数组的下标,把相应的元素存入数组中(二叉树的序号和结点有着相应的规律,之前有讲)

堆的基本操作:

下滤:将根点与其最大子节点进行比较,如果小于其最大子节点则进行交换,持续比较交换直到该元素大于其子节点为止或者移动到底部为止(主要用于新元素的加入,复杂度O(logN)可以重新构建成堆)

上滤:将最后一个节点与父节点进行比较,如果大于其父节点则进行交换直到无法上移为止

自顶向下建堆法:将新元素放到堆的最后一位,然后对其进行上滤操作,直到所有元素插入后完成建堆时间复杂度为O(N logN)

自下而上建堆法:将元素先调整成堆,然后再对父节点进行下滤操作,直到根结点操作完毕,这种建堆方法的时间复杂度为O(N)

优先队列:

弹出最小元素的队列可以用小根堆来实现,因为小根堆的根结点本来就是最小元素,所以直接弹出根结点即可完成弹出操作将最后一个元素放到根结点进行下滤操作即可,插入直接上滤即可

堆排序:

将大根堆结点按层序遍历不断弹出即为正序,

反之为倒叙

过程:

1.建堆,以大根堆为例,倒着检查第一个非叶结点,即n/2是否大于其左右结点,否则与左右节点中较大的数进行交换,并不断向下进行比较(直到大于等于其左右结点或者已经到叶结点了)

2.排序,不断检查更新最后的数,然后将放好的数隐藏掉

相关文章:

堆、优先队列、堆排序

堆: 定义: 必须是一个完全二叉树(完全二叉树:完全二叉树只允许最后一行不为满,且最后一行必须从左往右排序,最后一行元素之间不可以有间隔) 堆序性: 大根堆:每个父节点…...

vue 学习-vite api.js

/** 整机管理 * */ // 整机分类 列表 export const wholeMachineServersType params > ajaxGet({url: wholeMachine/serverstype/,params}) // 整机分类 新增 export const wholeMachineServersTypeAdd params > ajaxPost({url: wholeMachine/serverstype/,params}) /…...

java练习(35)

ps:题目来自力扣 整数反转 给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。 如果反转后整数超过 32 位的有符号整数的范围 [−231, 231 − 1] ,就返回 0。 假设环境不允许存储 64 位整数(有符号或无符号&#xff09…...

PW_Balance

目录 1、 PW_Balance 1.1、 getDocumentsTypeID 1.2、 getShouldAmount 1.3、 setOptimalAmount 1.4、 setRemark PW_Balance package com.gx.pojo; public class PW_Balance { private Integer BalanceID; private Integer PaymentID; private Integer ReceptionID…...

【Linux-网络】HTTP的清风与HTTPS的密语

🎬 个人主页:谁在夜里看海. 📖 个人专栏:《C系列》《Linux系列》《算法系列》 ⛰️ 道阻且长,行则将至 目录 📚 引言 📚 一、HTTP 📖 1.概述 📖 2.URL &#x1f5…...

【前端框架】vue2和vue3的区别详细介绍

Vue 3 作为 Vue 2 的迭代版本,在性能、语法、架构设计等多个维度均有显著的变革与优化。以下详细剖析二者的区别: 响应式系统 Vue 2 实现原理:基于 Object.defineProperty() 方法实现响应式。当一个 Vue 实例创建时,Vue 会遍历…...

CMake管理依赖实战:多仓库的无缝集成

随着软件复杂度的增加,单个项目可能需要依赖多个外部库或模块。这些依赖项可能是来自不同的代码仓库,如ATest和BTest。为了实现高效的依赖管理,CMake提供了多种方式来处理这种多仓库的情况。下面我们将详细介绍几种常见的方法,并通…...

Touchgfx 编写下载算法文件(.stldr)

一)下载算法文件主要参考官方的STM32 ST-LINK Utility模板:(文件所在位置如下:) C:\Program Files (x86)\STMicroelectronics\STM32 ST-LINK Utility\ST-LINK Utility\ExternalLoader\M25P64_STM3210E-EVAL\Project\MD…...

回不去的乌托邦

回不去的乌托邦 坐在电脑面前愣神间已至深夜,依然睡意不起。 相比于带着疲惫入睡,伏案发呆更令人惬意。想起最近在自媒体上看到的一句话“最顶级的享受变成了回不去的乌托邦”。 “这是兄弟们最后一次逛校园了,我拍个照”。我的记忆力总是用在…...

如何在 SpringBoot 项目使用 Redis 的 Pipeline 功能

本文是博主在批量存储聊天中用户状态和登陆信息到 Redis 缓存中时,使用到了 Pipeline 功能,并对此做出了整理。 一、Redis Pipeline 是什么 Redis 的 Pipeline 功能可以显著提升 Redis 操作的性能,性能提升的原因在于可以批量执行命令。当我…...

Linux----线程

一、基础概念对比 特性进程 (Process)线程 (Thread)资源分配资源分配的基本单位(独立地址空间)共享进程资源调度单位操作系统调度单位CPU调度的最小单位创建开销高(需复制父进程资源)低(共享进程资源)通信…...

实现rolabelimg对于dota格式文件的直接加载和保存

在本篇博客中,我们将讲解如何修改roLabelImg.py文件,使其能够直接加载和保存Dota格式的标注文件(txt)以替换掉复杂的xml文件。通过对源代码的修改,我们将实现支持加载并保存Dota格式标注数据,以便与roLabel…...

bboss v7.3.5来袭!新增异地灾备机制和Kerberos认证机制,助力企业数据安全

ETL & 流批一体化框架 bboss v7.3.5 发布,多源输出插件增加为特定输出插件设置记录过滤功能;Elasticsearch 客户端新增异地双中心灾备机制,提升框架高可用性;Elasticsearch client 和 http 微服务框架增加对 Kerberos 认证支持…...

华为昇腾服务器固件Firmware、驱动Drive、CANN各自的作用与联系?

文章目录 **1. 固件(Firmware)****2. 驱动(Driver)****3. CANN(Compute Architecture for Neural Networks)****三者关系****典型问题定位** 华为昇腾服务器的固件、驱动和CANN是支撑其AI计算能力的核心组件…...

MySQL 视图入门

一、什么是 MySQL 视图 1.1 视图的基本概念 在 MySQL 中,视图是一种虚拟表,它本身并不存储实际的数据,而是基于一个或多个真实表(基表)的查询结果集。可以把视图想象成是一个预定义好的查询语句的快捷方式。当你查询…...

算法很美笔记(Java)——动态规划

解重叠子问题(当前解用到了以前求过的解) 形式:记忆型递归或递推(dp) 动态规划本质是递推,核心是找到状态转移的方式,也就是填excel表时的逻辑(填的方式),而…...

C++ ——继承

体现的是代码复用的思想 1、子类继承父类,子类就拥有了父类的特性(成员方法和成员属性) 2、已存在的类被称为“基类”或者“父类”或者“超类”;新创建的类被称为“派生类”或者“子类” 注意: (1&#…...

LeetCode 热题 100 283. 移动零

LeetCode 热题 100 | 283. 移动零 大家好,今天我们来解决一道经典的算法题——移动零。这道题在LeetCode上被标记为简单难度,要求我们将数组中的所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。下面我将详细讲解解题思路,…...

游戏引擎学习第116天

回顾昨天的工作 本次工作内容主要集中在游戏开发的低级编程优化,尤其是手动优化软件渲染。工作目的之一是鼓励开发者避免依赖外部库,而是深入理解代码并进行优化。当前阶段正进行SIMD(单指令多数据)优化,使用Intel推荐…...

react(9)-redux

使用CRA快速创建react项目 npx create-react-app react-redux 安装配套工具 npm i reduxjs/toolkit react-redux 启动项目 在创建项目时候会出现一个问题 You are running create-react-app 5.0.0, which is behind the latest release (5.0.1). We no longer support…...

Python聚类分析实战:k-means与层次聚类详解

1. Python聚类分析入门指南聚类分析作为无监督学习的重要技术,在商业智能、生物信息学和图像处理等领域有着广泛应用。今天我将通过两个实际案例,带大家掌握Python中k-means和层次聚类这两种最常用的聚类方法。不同于教科书式的理论讲解,本文…...

别浪费那块旧硬盘!手把手教你为J1900软路由扩展存储并安装ESXi 6.7

旧硬盘重生计划:J1900软路由ESXi 6.7存储扩展实战指南 当你手头那台J1900工控机仅靠32GB mSATA硬盘在ESXi环境中捉襟见肘时,抽屉里吃灰的2.5寸机械硬盘或许正等待着一场华丽变身。本文将带你解锁三个硬件改造层级:从基础存储扩容到智能资源分…...

从GPS定位到机器人导航:一文讲透ROS中坐标系转换(WGS-84/UTM/ENU)的底层逻辑与实战

从GPS定位到机器人导航:一文讲透ROS中坐标系转换(WGS-84/UTM/ENU)的底层逻辑与实战 当你在机器人项目中第一次看到GPS数据在ROS中飘忽不定时,是否曾困惑于如何将这些经纬度数字变成机器人能理解的导航指令?坐标系转换就…...

测试笔记3

121212121...

ZynqMP启动镜像BOOT.bin生成详解:从FSBL、PMU到ATF和U-Boot的Vitis 2021.2配置全流程

ZynqMP启动镜像BOOT.bin生成全流程:从组件解析到Vitis实战配置 在嵌入式系统开发中,启动流程的设计与实现往往是项目成功的关键第一步。对于Xilinx Zynq UltraScale MPSoC这类异构多核处理器,其启动过程更像是一场精心编排的交响乐——每个组…...

C# WinForm 工作流设计 工作流程图拖拽设计 +GDI 绘制工作流程图 大概功能说明一...

C# WinForm 工作流设计 工作流程图拖拽设计 GDI 绘制工作流程图 大概功能说明一下:1.支持拖动绘制工作节点2.支持移动每个节点的移动3.支持直线连接节点4.支持节点移动连接线自动跟随5.支持高亮显示选中的节点连线6.支持能删除选中节点和连线7.支持选中节点能显示节…...

VSCode+大模型开发效率翻倍:3个被低估的AI插件配置技巧,今天不学明天就落后

更多请点击: https://intelliparadigm.com 第一章:VSCode大模型开发效率翻倍:3个被低估的AI插件配置技巧,今天不学明天就落后 现代开发者早已不再满足于基础补全——真正提升生产力的是**上下文感知、可编程、可定制的AI协同工作…...

Google TimesFM实战:零代码搞定时间序列预测(附数据集获取技巧)

Google TimesFM实战:零代码搞定时间序列预测(附数据集获取技巧) 时间序列预测一直是商业决策中的关键工具,从销售趋势分析到库存管理,再到市场需求预测,准确的时间序列预测能帮助企业提前布局,…...

IIC协议常见误区解析:从时序图到实际波形(附逻辑分析仪实测)

IIC协议实战避坑指南:从理论时序到真实波形的深度解析 调试IIC总线就像在跟一个性格内向的技术专家对话——协议规范看似简单明了,但实际交互中那些微妙的停顿、眼神交流和潜台词才是真正决定沟通成败的关键。本文将带您穿透理想时序图的表象&#xff0c…...

Kohya_SS完整指南:AI绘画模型训练与安装终极教程

Kohya_SS完整指南:AI绘画模型训练与安装终极教程 【免费下载链接】kohya_ss 项目地址: https://gitcode.com/GitHub_Trending/ko/kohya_ss Kohya_SS是一款功能强大的AI绘画模型训练工具,支持Stable Diffusion的微调、DreamBooth、LoRA和Textual …...