全网整合营销服务商

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

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

C++堆排序算法实例详解

本文实例讲述了C++堆排序算法。分享给大家供大家参考,具体如下:

堆中元素的排列方式分为两种:max-heap或min-heap,前者每个节点的key都大于等于孩子节点的key,后者每个节点的key都小于等于孩子节点的key。

由于堆可以看成一个完全二叉树,可以使用连续空间的array来模拟完全二叉树,简单原始的实现如下:

#include<iostream>
int heapsize=0;//全局变量记录堆的大小
void heapSort(int array[],int n){
 void buildHeap(int [],int);
 void exchange(int[],int,int);
 void heapify(int[],int);
 buildHeap(array,n);
 for(int i=n-1;i>=1;i--){
  exchange(array,0,i);
  heapsize--;
  heapify(array,0);
 }
}
//构建堆
void buildHeap(int array[],int n){
 void heapify(int[],int);
 heapsize=n;
 //从最小的父节点开始,进行堆化,直到树根节点
 for(int i=heapsize/2-1;i>=0;i--){
  heapify(array,i);
 }
}
//堆化
void heapify(int array[],int n){
 void exchange(int[],int,int);
 int left_child=n*2+1;
 int right_child=n*2+2;
 int largest;
 if(left_child<heapsize&&array[left_child]>array[n]){
  largest = left_child;
 }
 else{
  largest = n;
 }
 if(right_child<heapsize&&array[right_child]>array[largest]){
  largest=right_child;
 }
 if(largest!=n){
  exchange(array,largest,n);
  heapify(array,largest);
 }
}
void exchange(int array[],int i,int j){
 int tmp = array[i];
 array[i]=array[j];
 array[j]=tmp;
}
int main(){
  int arr[9]={3,1,6,9,8,2,4,7,5};
  heapSort(arr,9);
  for(int i=0;i<9;++i){
    std::cout<<arr[i]<<" ";
  }
  std::cout<<std::endl;
  return 0;
}
STL中实现了max-heap的操作。在使用heap算法是需添加头文件algorithm。
#include <iostream>
#include<vector>
#include<algorithm>
int main()
{
  int arr[9]={0,1,2,3,4,8,9,3,5};
  std::vector<int> vec(arr,arr+9);
  //0 1 2 3 4 8 9 3 5
  for(auto c:vec){
    std::cout<<c<<" ";
  }
  std::cout<<std::endl;
  make_heap(vec.begin(),vec.end());
  //9 5 8 3 4 0 2 3 1
  for(auto c:vec){
    std::cout<<c<<" ";
  }
  std::cout<<std::endl;
  vec.push_back(7);
  push_heap(vec.begin(),vec.end());
  //9 7 8 3 5 0 2 3 1 4
  for(auto c:vec){
    std::cout<<c<<" ";
  }
  std::cout<<std::endl;
  pop_heap(vec.begin(),vec.end());
  //8 7 4 3 5 0 2 3 1 9,只是将最大值挪到了vector的最后,并没有删除
  for(auto c:vec){
    std::cout<<c<<" ";
  }
  std::cout<<std::endl;
  std::cout<<vec.back()<<std::endl;//9
  //将9删除
  vec.pop_back();
  //连续的pop_heap操作,每次的最大值都放在最尾端,最后呈现递增排序
  sort_heap(vec.begin(),vec.end());
  //0 1 2 3 3 4 5 7 8
  for(auto c:vec){
    std::cout<<c<<" ";
  }
  std::cout<<std::endl;
  return 0;
}

希望本文所述对大家C++程序设计有所帮助。


# C++  # 堆排序  # 算法  # C++中二叉堆排序详解  # C++超详细实现堆和堆排序过像  # C++实现堆排序实例介绍  # C++实现堆排序示例  # C++ 数据结构 堆排序的实现  # C++堆排序算法的实现方法  # C++超详细分析优化排序算法之堆排序  # 放在  # 二叉树  # 两种  # 给大家  # 可以使用  # 所述  # 程序设计  # 堆中  # 实现了  # 头文件  # 全局变量  # 讲述了  # cpp  # include  # brush  # pre  # class  # int  # heapsize  # gt 


相关文章: 建站之星如何助力企业快速打造五合一网站?  如何通过商城自助建站源码实现零基础高效建站?  制作网站外包平台,自动化接单网站有哪些?  如何通过FTP空间快速搭建安全高效网站?  如何实现建站之星域名转发设置?  如何高效完成自助建站业务培训?  如何在VPS电脑上快速搭建网站?  微信小程序制作网站有哪些,微信小程序需要做网站吗?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  Swift中switch语句区间和元组模式匹配  建站主机空间推荐 高性价比配置与快速部署方案解析  制作网站公司那家好,网络公司是做什么的?  建站之星logo尺寸如何设置最合适?  如何选择美橙互联多站合一建站方案?  ,网页ppt怎么弄成自己的ppt?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  如何正确选择百度移动适配建站域名?  广德云建站网站建设方案与建站流程优化指南  如何在景安云服务器上绑定域名并配置虚拟主机?  Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  建站之星如何保障用户数据免受黑客入侵?  建站之星代理费用多少?最新价格详情介绍  建站DNS解析失败?如何正确配置域名服务器?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  简历在线制作网站免费版,如何创建个人简历?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  如何快速查询网址的建站时间与历史轨迹?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  ,在苏州找工作,上哪个网站比较好?  为什么Go需要go mod文件_Go go mod文件作用说明  如何通过宝塔面板实现本地网站访问?  IOS倒计时设置UIButton标题title的抖动问题  如何在万网自助建站中设置域名及备案?  香港服务器WordPress建站指南:SEO优化与高效部署策略  网站设计制作企业有哪些,抖音官网主页怎么设置?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  如何高效利用亚马逊云主机搭建企业网站?  如何选择高性价比服务器搭建个人网站?  建站之星24小时客服电话如何获取?  如何用wdcp快速搭建高效网站?  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  c# await 一个已经完成的Task会发生什么  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  大学网站设计制作软件有哪些,如何将网站制作成自己app? 

您的项目需求

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