C语言 数据结构堆排序顺序存储(升序)

发布时间 - 2026-01-11 01:13:43    点击率:

堆排序顺序存储(升序)

一: 完全二叉树的概念:前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语言数据结构之堆排序详解  # C语言数据结构之堆排序源代码  # C语言实现堆排序的简单实例  # C语言对堆排序一个算法思路和实现代码  # C语言植物大战数据结构堆排序图文示例  # 二叉树  # 升序  # 一棵  # 为大  # 数为  # 请输入  # 是一个  # 还没有  # 降序  # 希望能  # 就可  # 谢谢大家  # 不稳定  # 标志着  # 两步  # 判断是否  # 构建一个  # brush  # class  # nlogn 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 浅述节点的创建及常见功能的实现  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  Laravel如何处理和验证JSON类型的数据库字段  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  如何在阿里云购买域名并搭建网站?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】  如何获取PHP WAP自助建站系统源码?  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  Laravel如何实现事件和监听器?(Event & Listener实战)  如何快速生成专业多端适配建站电话?  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  javascript基本数据类型及类型检测常用方法小结  Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知  北京的网站制作公司有哪些,哪个视频网站最好?  如何快速查询网址的建站时间与历史轨迹?  公司网站制作价格怎么算,公司办个官网需要多少钱?  Swift中switch语句区间和元组模式匹配  微信小程序 闭包写法详细介绍  Laravel storage目录权限问题_Laravel文件写入权限设置  微信推文制作网站有哪些,怎么做微信推文,急?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  Laravel如何创建自定义Facades?(详细步骤)  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  如何快速查询域名建站关键信息?  Android使用GridView实现日历的简单功能  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  北京企业网站设计制作公司,北京铁路集团官方网站?  简单实现Android文件上传  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  如何快速搭建FTP站点实现文件共享?  如何在腾讯云服务器快速搭建个人网站?  html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】  如何在景安服务器上快速搭建个人网站?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  海南网站制作公司有哪些,海口网是哪家的?  香港服务器建站指南:免备案优势与SEO优化技巧全解析  Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)  公司网站制作需要多少钱,找人做公司网站需要多少钱?  怎么用AI帮你为初创公司进行市场定位分析?  Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】  Laravel如何配置和使用缓存?(Redis代码示例)  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  如何在Windows环境下新建FTP站点并设置权限?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法