堆排序顺序存储(升序)
一: 完全二叉树的概念:前h-1层为满二叉树,最后一层连续缺失右结点!
二:首先堆是一棵全完二叉树:
a:构建一个堆分为两步:⑴创建一棵完全二叉树 ⑵调整为一个堆
(标注:大根堆为升序,小根堆为降序)
b:算法描述:①创建一棵完全二叉树
②while(有双亲){
A:调整为大根堆;
B:交换根和叶子结点;
C:砍掉叶子结点;
}
c:时间复杂度为 O(nlogn) ,空间复杂度为 O(1), 是不稳定排序!
代码实现:
/*堆排序思想:[完全二叉树的定义:前 h-1 层为满二叉树一最后一层连续缺失右结点(即右子女)],(大根堆升序排序,小根堆降序排列) 首先堆是一个完全二叉树 ,根据数组下标就可建成了一棵完全二叉树 其次:while(有双亲){ A: 调整为一个大根堆 【Adjust()函数实现】 B: 交换最后一个叶子结点和根结点 【Swap()函数实现】 C: 砍掉最后一个叶子结点 【即元素个数 n--】 } */ #include <iostream> #define N 100 using namespace std; int b[N]={0}; //存储数据的数组 int n=0; //记录数据的总个数【0单元不要,实际元素个数为(n-1)个】 void Swap(int *x,int *y){ int t; t=*x; *x=*y; *y=t; } void Adjust(){ int p; //记录双亲结点 int tag=1; //记录是否已经调整为大根堆(标志性的变量) while(tag){ //判断是否已经调整好为大根堆 p=(n-1)/2; //最后一个双亲结点的下标 tag=0; //凡是交换后,tag=1,标志着还没有调整为大根堆,否则继续调整 while(p>0){ //确保有双亲结点 if(b[p]<b[2*p]){ //若根结点大于左子女结点,就交换 Swap(&b[p],&b[2*p]); tag=1; } if(2*p+1<n && b[p]<b[2*p+1]){ //若存在右子女,并且根结点大于右子女结点,就交换 Swap(&b[p],&b[2*p+1]); tag=1; } p--; //直到最后一个双亲结点调整完 } } } void HeapSort(){ while(n>2){ //保证有双亲结点 Adjust(); //调整大根堆函数 Swap(&b[1],&b[n-1]); //将最后一个叶子结点和根结点交换 n--; //裁剪最后的叶子结点 } } int main(void){ int i,m; cout<<"请输入数据的总数【0单元不要,实际元素个数为(n-1)个】:"<<endl; cin>>n; m=n; cout<<"请输入各个数据【0单元不要,实际元素个数为(n-1)个】:"<<endl; b[0]=0; for(i=1;i<n;i++){ cin>>b[i]; } HeapSort(); //堆排序 cout<<"大根堆升序排列为:"<<endl; for(i=1;i<m;i++){ cout<<b[i]<<" "; } cout<<endl; return 0; }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文向大家介绍C语言数据结构之堆排序源代码,包括了C语言数据结构之堆排序源代码的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了C语言堆排序源代码,供大家参考,具体内容如下 1. 堆排序 堆排序的定义及思想可以参考百度百科: 用一句概括,堆排序就是一种改进的选择排序,改进的地方在于,每次做选择的时候,不单单把最大的数字选择出来,而且把排序过程中的一些操作进行了记录,这样在后续排序中可以
主要内容:顺序表的初始化顺序表,全名 顺序存储结构,是 线性表的一种。通过《 什么是线性表》一节的学习我们知道,线性表用于存储逻辑关系为“一对一”的数据,顺序表自然也不例外。 不仅如此,顺序表对数据的物理存储结构也有要求。 顺序表存储数据时,会提前申请一整块足够大小的物理空间,然后将数据依次存储起来,存储时做到数据元素之间不留一丝缝隙。 例如,使用顺序表存储集合 ,数据最终的存储状态如图 1 所示: 图 1 顺序存储结
本文向大家介绍C++ 数据结构 堆排序的实现,包括了C++ 数据结构 堆排序的实现的使用技巧和注意事项,需要的朋友参考一下 堆排序(heapsort)是一种比较快速的排序方式,它的时间复杂度为O(nlgn),并且堆排序具有空间原址性,任何时候只需要有限的空间来存储临时数据。我将用c++实现一个堆来简单分析一下。 堆排序的基本思想为: 1、升序排列,保持大堆;降序排列,保持小堆; 2、建立堆之后,将
主要内容:图的顺序存储结构C语言实现使用图结构表示的数据元素之间虽然具有“多对多”的关系,但是同样可以采用顺序存储,也就是使用数组有效地存储图。 使用数组存储图时,需要使用两个数组,一个数组存放图中顶点本身的数据(一维数组),另外一个数组用于存储各顶点之间的关系(二维数组)。 存储图中各顶点本身数据,使用一维数组就足够了;存储顶点之间的关系时,要记录每个顶点和其它所有顶点之间的关系,所以需要使用二维数组。 不同类型的图,存储的方式略
本文向大家介绍Objective-C语言排序数组,包括了Objective-C语言排序数组的使用技巧和注意事项,需要的朋友参考一下 示例
本文向大家介绍C语言数据结构 链表与归并排序实例详解,包括了C语言数据结构 链表与归并排序实例详解的使用技巧和注意事项,需要的朋友参考一下 C语言数据结构 链表与归并排序实例详解 归并排序适合于对链表进行原址排序,即只改变指针的连接方式,不交换链表结点的内容。 归并排序的基本思想是分治法:先把一个链表分割成只有一个节点的链表,然后按照一定顺序、自底向上合并相邻的两个链表。 只要保证各种大小的子链表