全网整合营销服务商

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

免费咨询热线: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 


相关文章: 上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  如何获取免费开源的自助建站系统源码?  建站与域名管理如何高效结合?  如何在阿里云虚拟服务器快速搭建网站?  如何用免费手机建站系统零基础打造专业网站?  如何选择域名并搭建高效网站?  营销式网站制作方案,销售哪个网站招聘效果最好?  如何选择可靠的免备案建站服务器?  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  如何在宝塔面板中创建新站点?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  h5网站制作工具有哪些,h5页面制作工具有哪些?  如何打造高效商业网站?建站目的决定转化率  定制建站如何定义?其核心优势是什么?  高端建站如何打造兼具美学与转化的品牌官网?  如何高效完成独享虚拟主机建站?  公司网站设计制作厂家,怎么创建自己的一个网站?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  浅析上传头像示例及其注意事项  如何在VPS电脑上快速搭建网站?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  制作网站的过程怎么写,用凡科建站如何制作自己的网站?  大连网站制作公司哪家好一点,大连买房网站哪个好?  宝华建站服务条款解析:五站合一功能与SEO优化设置指南  ,制作一个手机app网站要多少钱?  宝塔建站后网页无法访问如何解决?  Bpmn 2.0的XML文件怎么画流程图  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  如何通过山东自助建站平台快速注册域名?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  图册素材网站设计制作软件,图册的导出方式有几种?  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  青浦网站制作公司有哪些,苹果官网发货地是哪里?  如何通过IIS搭建网站并配置访问权限?  如何快速搭建支持数据库操作的智能建站平台?  攀枝花网站建设,攀枝花营业执照网上怎么年审?  如何选择香港主机高效搭建外贸独立站?  油猴 教程,油猴搜脚本为什么会网页无法显示?  如何生成腾讯云建站专用兑换码?  制作网站的模板软件,网站怎么建设?  如何快速搭建二级域名独立网站?  如何快速启动建站代理加盟业务?  如何访问已购建站主机并解决登录问题?  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  实惠建站价格推荐:2025年高性价比自助建站套餐解析  广州网站建站公司选择指南:建站流程与SEO优化关键词解析 

您的项目需求

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