堆排序顺序存储(升序)

一: 完全二叉树的概念:前h-1层为满二叉树,最后一层连续缺失右结点!

二:首先堆是一棵全完二叉树:

a:构建一个堆分为两步:⑴创建一棵完全二叉树      ⑵调整为一个堆

(标注:大根堆为升序,小根堆为降序)

b:算法描述:①创建一棵完全二叉树

②while(有双亲){

A:调整为大根堆;

B:交换根和叶子结点;

C:砍掉叶子结点;

}

c:时间复杂度为 O(nlogn)  ,空间复杂度为 O(1), 是不稳定排序!

代码实现:

/*堆排序思想:[完全二叉树的定义:前 h-1 层为满二叉树一最后一层连续缺失右结点(即右子女)],(大根堆升序排序,小根堆降序排列)

首先堆是一个完全二叉树 ,根据数组下标就可建成了一棵完全二叉树

其次:while(有双亲){

A: 调整为一个大根堆 【Adjust()函数实现】

B: 交换最后一个叶子结点和根结点 【Swap()函数实现】

C: 砍掉最后一个叶子结点 【即元素个数 n--】

}

*/

#include

#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]

Swap(&b[p],&b[2*p]);

tag=1;

}

if(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<

cin>>n;

m=n;

cout<

b[0]=0;

for(i=1;i

cin>>b[i];

}

HeapSort(); //堆排序

cout<

for(i=1;i

cout<

}

cout<

return 0;

}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

c语言顺序存储构建一棵二叉树,C语言 数据结构堆排序顺序存储(升序)相关推荐

  1. C语言递归遍历一棵二叉树(附完整源码)

    C语言递归遍历一棵二叉树 结点结构体定义 二叉树递归遍历方式 完整实现和main测试源码 结点结构体定义 struct node {struct node *leftNode;int data;str ...

  2. c语言创建树,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  3. C语言六叉树,递归创建二叉树c语言实现+详细解释

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 void CreatBiTree(BiTree T) { char a; scanf("%c",&a); if(a=='@') ...

  4. 哪两种遍历方式可以唯一确定一棵二叉树,结合力扣105题

    对于一棵树的前中序三种顺序的遍历方式,任何一种单独拿出来都无法确定一棵树,那么两种遍历方式得到的节点数据能否构建一棵二叉树呢? 先来看看能有哪几种组合: 先序遍历 + 中序遍历 后序遍历 + 中序遍历 ...

  5. R语言如何构建正交多项式回归?

    R语言如何构建正交多项式回归? 目录 R语言如何构建正交多项式回归? R语言是解决什么问题的? R语言如何构建正交多项式回归? 安利一个R语言的优秀博主及其CSDN专栏: R语言是解决什么问题的? R ...

  6. c语言创建字符树,使用C语言构建基本的二叉树数据结构

    二叉树结构常用的一些初始化代码 #include #include typedef struct Node{ int data; Node *leftchild; Node *rightchild; ...

  7. C语言求一棵二叉树所有根到叶的路径(附完整源码)

    C语言求一棵二叉树所有根到叶的路径 C语言求一棵二叉树所有根到叶的路径完整源码(定义,实现,main函数测试) C语言求一棵二叉树所有根到叶的路径完整源码(定义,实现,main函数测试) #inclu ...

  8. 已知一棵完全二叉树存于顺序表sa中,sa.elem[1..sa.length]含结点值,试编写算法由此顺序存储结构建立该二叉树的二叉链表。

    已知一棵完全二叉树存于顺序表sa中,sa.elem[1-sa.length]含结点值,试编写算法由此顺序存储结构建立该二叉树的二叉链表. 分析:由二叉树的性质可知,一个下标为i的节点若有左子树,则其左 ...

  9. <二叉树>《数据结构(C语言版)》

    目录 <数据结构(C语言版)>实战项目之二叉树 --By 作者:新晓·故知 1.树的概念及结构 1.1树的概念 1.2 树的相关概念 1.3 树的表示 1.4 树在实际中的运用(表示文件系 ...

最新文章

  1. Docker Compose基本介绍
  2. c语言标准io中可读可写,C语言标准IO: [先读再feof] VS [先feof再读]
  3. 《ASP.NET Core 高性能系列》致敬伟大的.NET斗士甲骨文
  4. 什么是高清DVI光端机?dvi光端机的技术参数及应用有哪些?
  5. 独家揭秘!抖音爆款实时视频漫画变身特效背后技术
  6. Java通过BCrypt加密
  7. Dxg——AD(Altium Designer) 开发笔记整理分类合集【所有的相关记录,都整理在此】
  8. excel分段函数c语言,实战:Excel 逻辑分段函数应用
  9. uni-app 更改头部导航条背景,改成背景图
  10. 1096 大美数 分数 15
  11. mysql 表分区 排序_mysql 表分区
  12. 7.14英语学习:英国拍争议文物
  13. Kubernetes切换Docker容器引擎为Containerd
  14. 微信小程序 保存base64图片和普通图片
  15. BQ25798双电源输入4节电池升降压充电与最大功率跟踪于光伏板应用
  16. Ubuntu下载安装
  17. 关于【统一权限系统】概况
  18. 火炬之光(TorchLight)使用的Ogre粒子系统插件ParticleUniverse研究
  19. 科普:互联网的盈利模式
  20. APS炒币机器人的投资随记No.3:主流币向上突破之后的三个方向

热门文章

  1. Linux 命令(110)—— help 命令(builtin)
  2. Codeforces Round #879 (Div. 2) C. Short Program
  3. django上课笔记6-MVC,MTV架构-中间件-初识Form组件
  4. 签名别人的公钥以及验证签名的公钥
  5. PHP用substr截取字符串出现中文乱码问题用mb_substr
  6. 限制firefox上传框宽度
  7. CSS实现兼容性的渐变背景(gradient)效果(转)
  8. jquery 设置 select 默认值方法
  9. linux去掉空行的几种方法
  10. WINDOWS登录系统之前(欢迎界面)运行指定程序脚本服务