全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

堆排序顺序存储(升序)

一: 完全二叉树的概念:前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 


相关文章: 娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  开心动漫网站制作软件下载,十分开心动画为何停播?  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  制作电商网页,电商供应链怎么做?  中山网站推广排名,中山信息港登录入口?  建站10G流量真的够用吗?如何应对访问高峰?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  网站企业制作流程,用什么语言做企业网站比较好?    建站之星后台密码如何安全设置与找回?  如何快速生成高效建站系统源代码?  c# 在高并发场景下,委托和接口调用的性能对比  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  宝塔面板如何快速创建新站点?  想学网站制作怎么学,建立一个网站要花费多少?  如何批量查询域名的建站时间记录?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  ,网站推广常用方法?  如何快速查询网站的真实建站时间?  定制建站方案优化指南:企业官网开发与建站费用解析  建站之星多图banner生成与模板自定义指南  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  如何在Golang中引入测试模块_Golang测试包导入与使用实践  建站之星展会模版如何一键下载生成?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何做静态网页,sublimetext3.0制作静态网页?  如何设计高效校园网站?  如何快速搭建支持数据库操作的智能建站平台?  如何通过可视化优化提升建站效果?  如何在阿里云香港服务器快速搭建网站?  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  网站微信制作软件,如何制作微信链接?  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  常州自助建站费用包含哪些项目?  网站网页制作专业公司,怎样制作自己的网页?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  如何解决ASP生成WAP建站中文乱码问题?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  北京建设网站制作公司,北京古代建筑博物馆预约官网?  如何在Windows虚拟主机上快速搭建网站?  北京网站制作的公司有哪些,北京白云观官方网站?  行程制作网站有哪些,第三方机票电子行程单怎么开?  制作网站怎么制作,*游戏网站怎么搭建?  如何选择高效便捷的WAP商城建站系统?  C#如何使用XPathNavigator高效查询XML  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  c++ stringstream用法详解_c++字符串与数字转换利器 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。