最小堆和最大堆的建立以及基本操作

前言:

堆的特性:用数组表示的完全二叉树。有序性:任一结点的关键字是其子树所有结点的最大值 (最小值)
堆的本质:就是一颗 完全二叉树
堆的数据存储: 用的是 数组
建堆时主要的操作:就是调整 对数组的元素按照已有的顺序建立的完全二叉树 进行调整(根据建最大堆或是最小堆)。

建立最小堆

#include<bits/stdc++.h>
using namespace std;// 根据 已有的数组 进行调整(向下调整)如果 孩子比关键值小 就交换;
void downadjust(int heap[],int adjust,int last){//adjust时待调整的下标 last是数组最后的下标int i = adjust;int j = 2 * i;//为i的左孩子while ( j <= last){if( j + 1 <=last && heap[j+1] < heap[j]){//比较 关键值的左右孩子 谁更小j++;}if( heap[i] > heap[j]){//如果待调整的点比其孩子值(已将其左右孩子的最小值进行比较)大 那么就交换swap(heap[i],heap[j]);i = j;    //完成交换 将其孩子的下标赋值给 待调整值得下标j = 2 * i;//因为 现在 待调整点得下标更新了 所以 其孩子得下标也得更新 (方便继续向下调整)}else{break;//如果待调整的值 已经比其孩子的值小那就不需要调整;}}} //创建堆的函数
void creatheap(int heap[],int n){int i;for(i = n / 2; i >= 1; i--){//完全二叉树当中其[1,n/2]为非叶子结点的下标  在已经有的完全二叉树当中(进行调整,那么调整的效果 从非叶子结点开始较好)downadjust(heap,i,n);}
}//删除堆顶元素
int deletetop(int heap[],int last){int temp = heap[1]; heap[1] = heap[last];//将最后一个元素赋值给堆顶元素 然后再进行向下调整heap[last] = temp;last--;downadjust(heap,1,last);//从 堆顶开始 向下调整 return temp;
}//(向上调整 与其双亲比较大小 如果 比双亲小 那就交换)插入元素要用的函数
void upadjust(int heap[],int last){//向上调整 (将要插入的元素放到数组的最后面,然后与其双亲进行比较)int i = last;int j = i / 2;//表示其双亲while( j >= 1){//只要父母不是堆顶就调整if(heap[i] < heap[j]){swap(heap[i], heap[j]);i = j; //将其父母的下标赋值给待调整的下标j = i/2;//更新 其父母的下标}else{break;//说明插入的已经比其父母的值小 那就不用调整。}}
}//插入函数
void insert(int heap[],int last,int x){heap[++last] = x; //++last先开辟空间比如 last=8 ;++last = 9; last++ = 8;upadjust(heap,last);
}//堆排序  (这样输出的顺序 是降序)
void sortheap(int heap[],int last){for(int i = last; i >= 1; i--){swap(heap[1],heap[i]);downadjust(heap,1,i-1);//每次将最小的放到最后面 然后调整 前面(i-1)个元素}
}int main(){int heap[6] ={0,2,1,3,4,5}; //数组的第一个值为0 我们是从 i = 1;开始的, 如果 没有 0 那么2对应的下标就为0    creatheap(heap,5);//    cout << "依次删除堆顶元素 那么出来的顺序是升序 " << endl;
//    for(int i = 5; i >= 1; i--){
//    	int number = deletetop(heap,i);
//        cout<< number <<' ';
//    }cout<<endl;cout<<"插入元素7 并逆序输出"<<endl;insert(heap,5,7);sortheap(heap,6);for(int i = 1; i < 7; i++){//如果想要升序输出的话可以 将 i=6;i>=1;i--;即可升序输出 printf("%d ",heap[i]);}
}

运行 结果 :
在这里插入图片描述

建立最大堆

#include<bits/stdc++.h>
using namespace std; //向下调整建堆函数。 
void downadjust(int heap[],int adjust,int last){     //heap[]为实现堆的数组,adjust是待调整结点的下标,last为最后一个数组元素的小标。int i=adjust,j=2*i;                              //i为工作下标,j是预调整结点的左孩子。 while(j<=last){if(j+1<=last&&heap[j+1]>heap[j]){            //选择左右孩子结点值更大的那一个 j++;} if(heap[j]>heap[i]){                        // 如果左右孩子中最大的那个都比待调整结点要大 swap(heap[i],heap[j]);               //交换两个结点的值 i=j;                                 //i更新,始终记录待调整节点的下标 j=2*i;                               //j更新为i的左孩子 } else{                          //如果待调整结点的值比左右孩子结点都要大,那么停止。 break;}}   
}
void creatheap(int heap[],int n){           //堆的建立 for(int i=n/2;i>=1;i--){                //从最后一个非叶子结点进行 downadjust(heap,i,n);}
} 
void del(int heap[],int n){          //从堆中删除结点。 堆顶元素出去。  n为结点的个数 heap[1]=heap[n];                 //用最后一个元素将第一个元素(堆顶元素弹出)覆盖,然后从上往下调整 n--;downadjust(heap,1,n);
} 
void upadjust(int heap[],int last){     //添加一个元素,首先将其添加到堆的最后一个位置,然后向上调整即可 int i=last,j=i/2;                //i记录最后一个元素(即待调整元素)的下标,j记录了i的父亲结点的下标 while(j>=1){if(heap[i]>heap[j]){         //如果待调整元素的值要大于其父亲节点的值,那么交换 swap(heap[i],heap[j]);i=j;j=i/2;                 //更新i,j }else{break;}}
}
void insert(int heap[],int n,int x){   // 将新元素x添加到最后一个位置。然后向上调整 heap[++n]=x;upadjust(heap,n);
}void heapsort(int heap[],int n){    creatheap(heap,n);               //建堆 for(int i=n;i>=1;i--){     //从后往前遍历 swap(heap[1],heap[i]);      //交换堆顶和i号位的结点 downadjust(heap,1,i-1);    //调整 }
}int main()
{int heap[13]={0,3,6,1,9,3,13,56,77,12,45,43,65};heapsort(heap,12) ;for(int i=1;i<=12;i++){printf("%d ",heap[i]);}}

运行结果:
在这里插入图片描述

结尾

加油 陌生人 指的是默默努力素未谋面的生人;

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

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

相关文章

[C#.NET 拾遗补漏]06:单例模式最佳实践

阅读本文大概需要 3 分钟。大家好&#xff0c;这是【C#.NET 拾遗补漏】专辑的第 06 篇文章。今天讲讲大家熟悉的单例模式。单例模式大概是所有设计模式中最简单的一种&#xff0c;如果在面试时被问及熟悉哪些设计模式&#xff0c;你可能第一个答的就是单例模式。单例模式的实现…

字符串是单一字符的无序组合吗_Python学习笔记(八)组合数据类型

Python语言中最常用的组合数据类型有3大类&#xff0c; 分别是集合类型、序列类型和映射类型。集合类型是一个具体的数据类型名称&#xff0c;而序列类型和映射类型是一类数据类型的总称。集合类型是一个元素集合&#xff0c;元素之间无序&#xff0c;相同元素在 集合中唯一存在…

[MyBatisPlus]条件构造器wapper

wapper简介 QueryWrapper 组装查询条件 查询用户名包含a&#xff0c;年龄在20到30之间&#xff0c;邮箱信息不为null的用户信息 package com.xxxx.mybatisplus;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.xxxx.mybatisplus.mapper.Use…

7-6 列出连通集 (25 分)(详解)

列出连通集 1&#xff1a;思路 &#xff1a; 利用了邻接矩阵储存数据并建图&#xff0c;然后就是 DFS遍历和BFS遍历 只不过是本题需要输出的是非连通图 连通分量 外加俩函数搞定2&#xff1a;上码 #include<bits/stdc.h> using namespace std;//一些量的定义 queue<…

推荐:适合小白入门的Asp.Net Core 开源学习手册

前言推荐一个入门级的.NET Core开源项目&#xff0c;非常适合新手入门学习.NET Core。开源地址:https://github.com/windsting/little-aspnetcore-book。手册在线下载地址&#xff1a;https://nbarbettini.gitbooks.io/little-asp-net-core-book/content/chapters/mvc-basics/c…

从当前元素继续寻找_云漫圈 | 寻找无序数组的第k大元素

戳蓝字“CSDN云计算”关注我们哦&#xff01;作者&#xff1a;小灰来源&#xff1a;程序员小灰本期封面作者&#xff1a;泰勒太乐————— 第二天 —————题目是什么意思呢&#xff1f;比如给定的无序数组如下&#xff1a;如果 k6&#xff0c;也就是要寻找第6大的元素&a…

DFS和BFS总结和代码演示(详解)

1&#xff1a;BFS 广度优先搜索类似于树的层次遍历过程。它需要借助一个队列来实现。如图2-1-1所示&#xff0c;要想遍历从v0到v6的每一个顶点&#xff0c;我们可以设v0为第一层&#xff0c;v1、v2、v3为第二层&#xff0c;v4、v5为第三层&#xff0c;v6为第四层&#xff0c;再…

Kestrel的ListenAnyIP和ListenLocalhost的区别

问题在上篇文章&#xff0c;把AAStore.ProductCatalog.Api部署到docker中运行&#xff0c;输入地址访问报错如下图&#xff0c;说明外部无法访问这个url。&#xff08;当然本地开发环境测试是可以访问的&#xff09;。后来修改此处options.ListenLocalhost(8081)的代码改成opti…

[MyBatisPlus]Plus分页插件的配置和使用

Plus分页插件的配置和使用 配置类 package com.xxxx.mybatisplus.config;import com.baomidou.mybatisplus.annotation.DbType; import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.inner.Pagin…

控制是否展示_现场展示板管理不在于看,而在于管!

点击上方"五株科技"&#xff0c;关注公众号&#xff0c;天天有精彩&#xff01;一位日本专家根据研究数据宣称&#xff0c;如果中国的中小企业有效实行车间展示板管理&#xff0c;最大能够提升生产效率30%以上。通常被管理者小视的车间展示板&#xff0c;在专家眼中却…

7-7 六度空间 (30 分)(BFS遍历详解)(DFS最后一个点过不去)

7-7 六度空间 (30 分) 一&#xff1a;题目&#xff1a; 六度空间”理论又称作“六度分隔&#xff08;Six Degrees of Separation&#xff09;”理论。这个理论可以通俗地阐述为&#xff1a;“你和任何一个陌生人之间所间隔的人不会超过六个&#xff0c;也就是说&#xff0c;最…

龙芯完成.NET移植稳步推进生态建设

不久前&#xff0c;龙芯团队完成了.Net Core 3.1在龙芯上的移植。早在1年前&#xff0c;一位网友就告知&#xff0c;希望.Net能够移植到龙芯平台&#xff0c;因为一些政务应用场景有这方面的需求。只不过了一年&#xff0c;这就问题就被龙芯团队解决了。龙芯团队之所以移植.Net…

[MyBatisPlus]乐观锁和悲观锁

乐观锁和悲观锁 场景 一件商品&#xff0c;成本价是80元&#xff0c;售价是100元。老板先是通知小李&#xff0c;说你去把商品价格增加50元。小李正在玩游戏&#xff0c;耽搁了一个小时。正好一个小时后&#xff0c;老板觉得商品价格增加到150元&#xff0c;价格太高&#xf…

moore 数据集_警报数据集(alarm dataset)_机器学习_科研数据集

警报数据集(alarm dataset)数据摘要&#xff1a;The following datasets were used in Moore and Wong (2003),Optimal Reinsertion: A new search operator for accelerated and moreaccurate Bayesian network structure learning, ICML 2003.They are stored in this form o…

7月30日 举办专注于微服务的.NET Conf Focus

2020 年 7 月 30 日, 由.NET基金会和微软 将举办一个在线和为期一天的活动&#xff0c;包括 微软 .NET 团队的演讲者以及社区的演讲者。本次在线大会 专注.NET框架构建微服务&#xff0c;演讲者分享构建和部署云原生应用程序的最佳实践、模式、提示和技巧。有关更多信息和随时了…

7-8 哈利·波特的考试 (25 分)(详解+思路分析)真香啊

一&#xff1a;题目&#xff1a; 哈利波特要考试了&#xff0c;他需要你的帮助。这门课学的是用魔咒将一种动物变成另一种动物的本事。例如将猫变成老鼠的魔咒是haha&#xff0c;将老鼠变成鱼的魔咒是hehe等等。反方向变化的魔咒就是简单地将原来的魔咒倒过来念&#xff0c;例…

[SpringBoot2]welcomefavicon

欢迎页支持 ● 静态资源路径下 index.html ○ 可以配置静态资源路径 ○ 但是不可以配置静态资源的访问前缀。否则导致 index.html不能被默认访问 ● controller能处理/index 自定义 Favicon favicon.ico 放在静态资源目录下即可。

go语言io reader_go语言之IO操作(待补充)

前言在Go中,输入和输出操作都是使用原语实现的,原语将数据模拟成可读的或者可写的字节流。而Go的io包提供了io.Reader(将数据从某个资源读取到传输缓冲区被流式传输和使用)和io.Writer(从缓冲区读取数据,并写入目标资源)接口。实现了io.Reader接口的唯一方法Read(p []byte)(n i…

ABPHelper.CLI及其依赖项简单介绍

图片gif无法查看&#xff0c;请查看原文至博客园查看详情。目录目录ABPHelper.CLIScriban通过Microsoft.Extensions.FileProviders.Embedded获取嵌入资源通过静态方法获取文件内容使用Microsoft.Extensions.FileProviders.Physical获取文件内容Microsoft.CodeAnalysis.CSharpHu…

文件的创建与读取 文件的数据添加

文件的创建与读取 文件的数据添加 一&#xff1a;概要 1&#xff1a;首先要站在程序的角度上。 2&#xff1a;文件的创建 即将程序中的数据 写入到文件当中。 3&#xff1a;文件的读取 即将一个文件中的信息读取到程序当中。 二&#xff1a;步骤 1&#xff1a;创建文件…