堆的实现-适用于算法竞赛

首先讲一下能够实现的操作。

  1. 插入一个数
  2. 查找最小值
  3. 删除最小值
  4. 删除任意一个元素
  5. 修改任意一个元素

什么是堆?

堆其实是一棵完全二叉树。

即处理叶子节点和倒数第一层节点,其他节点都有两个子节点,而且顺序是从上到下,从左到右。

小根堆:每个节点都满足小于等于左右儿子节点。

堆有down和up操作。

何为down?

何为up?

操作

插入一个数heap[++size]=x;up(size)在尾部插入,后维护
查找最小值head[1];
删除最小值heap[1]=heap[size];size--;down(1)
删除任意一个元素heap[k]=heap[size];size--;down(k);up(k)
修改一个元素heap[k]=x;down(k);up(k)

例题:
 

输入一个长度为 𝑛 的整数数列,从小到大输出前 𝑚 小的数。

输入格式

第一行包含整数 𝑛 和 𝑚。

第二行包含 𝑛 个整数,表示整数数列。

输出格式

共一行,包含 𝑚 个整数,表示整数数列中前 𝑚 小的数。

数据范围

1≤m≤n≤1e5,1≤𝑚≤𝑛≤1e5,
1≤数列中元素≤1e9,1≤数列中元素≤1e9

输入样例:
5 3
4 5 1 3 2
输出样例:
1 2 3

代码:

#include<iostream>
#include<algorithm>
using namespace std;
const int N = 1e6+10;
int heap[N],idx;
void down(int u){int t =u;//假设t是在此节点和其左右儿子节点中最小的,初始时将t赋值为u(此节点)。if(2*u<=idx && heap[2*u]<heap[t]) t = 2*u;if(2*u+1 <= idx && heap[2*u+1]<heap[t]) t = 2*u+1;if(u != t){swap(heap[u],heap[t]);down(t);}
}int main(){int n,m;scanf("%d%d",&n,&m);idx=n;for(int i=1;i<=n;i++){scanf("%d",&heap[i]);}for(int i=n/2;i>=1;i--){down(i);}while(m--){printf("%d ",heap[1]);heap[1]=heap[idx];idx--;down(1);}return 0;
}

单独拿出down和up操作

down:

void down(int u){int t =u;//假设t是在此节点和其左右儿子节点中最小的,初始时将t赋值为u(此节点)。if(2*u<=idx && heap[2*u]<heap[t]) t = 2*u;if(2*u+1 <= idx && heap[2*u+1]<heap[t]) t = 2*u+1;if(u != t){swap(heap[u],heap[t]);down(t);}
}
//注意u是当前节点,在堆上的索引,idx是当前已经用的索引的个数(相当于每个元素的身份证编号,从小到大开始编号)。
//2*u表示当前节点u的左儿子节点的身份证号,heap[2*u]表示左儿子节点的值。2*u<=idx表示存在左儿子,
//因为如果计算出来的身份证编号比现在有的最大的编号还大,就说明计算出来的编号不存在。

up:

void up(int u){while( u/2 >0 && heap[u] < heap[u/2]){swap(heap[u],heap[u/2]);u=u/2;}
}
//u/2表示当前节点u的父节点的编号,一个节点只有一个父节点

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

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

相关文章

使用VMware安装Linux虚拟机

一、下载 通过百度网盘分享的文件&#xff1a;CentOS系统安装包 链接&#xff1a;https://pan.baidu.com/s/1_eqYl8HcNt2GcGDjgOElgg 提取码&#xff1a;cu07 二、安装 &#xff08;1&#xff09;双击打开软件 &#xff08;2&#xff09; 创建新的虚拟机 &#xff08;3&…

PyQt ERROR:ModuleNotFoundError: No module named ‘matplotlib‘

Solution:打开cmd输入指令下载malplotlib pip install matplotlib

微软第四季度财报预览:增长动力追踪

微软公司即将在2024年7月30日&#xff08;周二&#xff09;美国市场收盘后发布第四季度财务结果。 微软的收益 - 预期如何 美股券商开户通道 市场预计&#xff0c;微软即将到来的2024年第四季度的收入将年增长14.5%&#xff0c;达到644亿美元&#xff0c;高于2023年第四季度…

linux添加普通用户后无法使用K8S的kubectl命令怎么办/Linux普通用户管理K8S/Linux下普通用户无法使用K8S命令

1.给Linux添加普通用户 sudo useradd mqq #添加mqq账号 sudo passwd mqq #给mqq账号设置密码&#xff0c;需要输入2次&#xff0c;我输入密码是Admin1232.利用mqq用户输入K8S命令报错 3.给mqq用户提权 suduers文件位于路径/etc/sudoers #编辑文件/etc/sudoers vim /etc/su…

Matlab编程资源库(10)离散傅立叶变换

一、离散傅立叶变换算法简要 给定一个N点的离散信号序列x(n)&#xff0c;其中n表示时刻&#xff0c;n 0, 1, 2, ..., N-1。 定义离散傅立叶变换的频域序列X(k)&#xff0c;其中k表示频率&#xff0c;k 0, 1, 2, ..., N-1。 通过以下公式计算每个频率对应的复数值&#xff…

03。正式拿捏ArkTS语言第一天

1, 打印日志命令 &#xff1a; console.log() 2, 三种基本数据类型&#xff1a; number 数字类型 &#xff08;数字&#xff09; string 字符串类型&#xff08;例如&#xff1a;“我是字符串”&#xff09; boolean 布尔类型 (true 或者 false) ***…

【C语言报错已解决】Use of Uninitialized Variable

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 引言&#xff1a; 在编程中&#xff0c;未初始化的变量是一个常见的问题&#xff0c;它可能导致程序的行为变得不可预测。未初…

Matlab更换主题颜色附代码

解压后参考记录本教程 GitHub - scottclowe/matlab-schemer: Apply and save color schemes in MATLAB with ease. 本博客绑定了资源

【前端 08】简单学习js字符串

JavaScript中的String对象详解 在JavaScript中&#xff0c;字符串&#xff08;String&#xff09;是一种非常基础且常用的数据类型&#xff0c;用于表示文本数据。虽然JavaScript中的字符串是原始数据类型&#xff0c;但它们的行为类似于对象&#xff0c;因为JavaScript为字符…

windows 安装 Linux 子系统 Ubuntu,并编译安装nginx

1. 安装Ubuntu 首先可以在 Microsoft Store 自行搜索安装 Ubuntu&#xff0c;个人建议安装 22 版本的即可。Ubuntu安装完成后&#xff0c;以管理员身份打开CMD&#xff0c;运行如下命令&#xff1a; wsl --install 此时打开Ubuntu已经可以正常使用了。 2. 安装C/C编译器 对于…

java算法day25

java算法day25 广度优先搜索岛屿数量深搜岛屿数量广搜 广度优先搜索 核心&#xff1a;从起点出发&#xff0c;以起始点为中心一圈一圈进行搜索&#xff0c;一旦遇到终点&#xff0c;记录之前走过的节点就是一条最短路。搜索的方式是上下左右 一张图说明白模拟过程&#xff1…

【C语言】深入探讨数组传参

一、数组传参简介 在C语言中&#xff0c;数组传参是一个常见的操作&#xff0c;尤其是在处理大量数据或需要多次访问相同数据集时。理解如何传递数组以及这些方法之间的差异是编写高效和安全代码的关键。在这篇博客中&#xff0c;我们将详细讨论C语言中数组传参的几种常见方法&…

rhce THE homework of first

ssh远程免密登录成功 下载httpd和nginx 关闭防火墙 查看selinux的状态 为服务器配置ip 填充网站的内容 添加服务器配置

Python爬虫入门01:在Chrome浏览器轻松抓包

文章目录 爬虫基本概念爬虫定义爬虫工作原理爬虫流程爬虫类型爬虫面临的挑战 使用Chrome浏览器抓包查看网页HTML代码查看HTTP请求请求头&#xff08;Request Header&#xff09;服务器响应抓包的意义 爬虫基本概念 爬虫定义 爬虫&#xff08;Web Crawler 或 Spider&#xff0…

MongoDB教程(二十三):关于MongoDB自增机制

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝你生活愉快&#xff01; 文章目录 引言一、MongoD…

数字孪生在奥运会上的应用

数字孪生是一种精确的虚拟空间表示&#xff0c;能够实时模拟场馆内的各种变化或场景。国际奥委会正在确定高价值的应用案例和技术要求&#xff0c;将应用案例分为六个主要领域&#xff1a;场馆规划、利益相关者支持与参与、操作准备、粉丝体验、遗产和运营效率。每个案例将基于…

【前端 13】Vue快速入门

Vue快速入门 在现代Web开发中&#xff0c;尽管通过HTML、CSS和JavaScript我们能够构建出美观且功能丰富的页面&#xff0c;但随着项目规模的增大&#xff0c;这种传统的开发方式在效率上逐渐显得力不从心。为了提高开发效率&#xff0c;前端开发者们引入了多种框架和库&#x…

MySQL环境的配置文件json

突然了解到&#xff0c;使用json文件去进行环境的配置&#xff0c;这样修改参数的时候就只需要去改json文件中的内容&#xff0c;不需要去修改代码中的内容&#xff0c;其他人的MySQL和我的MySQL也不同&#xff0c;这时其他人只需要修改json文件中的内容&#xff0c;清晰明了&a…

基于STC8H系列单片机的定时器系统

基于STC8H系列单片机的定时器系统 STC8H4K64TL单片机介绍STC8H4K64TL单片机管脚图&#xff08;48个引脚&#xff09;STC8H4K64TL单片机串口仿真与串口通信STC8H4K64TL单片机管脚图&#xff08;32个引脚&#xff09;STC8H4K64TL单片机管脚图&#xff08;20个引脚&#xff09;STC…

Apollo使用(3):分布式docker部署

Apollo 1.7.0版本开始会默认上传Docker镜像到Docker Hub&#xff0c;可以按照如下步骤获取 一、获取镜像 1、Apollo Config Service 获取镜像 docker pull apolloconfig/apollo-configservice:${version} 我事先下载过该镜像&#xff0c;所以跳过该步骤。 2、Apollo Admin S…