国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

建最小堆min_heap_sort

2019-11-14 13:08:34
字體:
來源:轉載
供稿:網友

建最小堆與最大堆方法相同 只要改動max_heapify()函數里的判斷條件即可.

#include<iostream>

using namespace std;int Parent(int i){return i/2;}int Left(int i){return 2*i;}int Right(int i){return 2*i+1;}void exchange(int *a,int *b){int t=*a;*a=*b;*b=t;}void min_heapify(int *a,int i,int heap_size){int l=Left(i);int r=Right(i);int smallest;if(l<=heap_size&&a[l]<a[i])//改動smallest=l;elsesmallest=i;if(r<=heap_size&&a[r]<a[smallest]) ///改動smallest=r;if(smallest!=i){    exchange(&a[smallest],&a[i]);    min_heapify(a,smallest,heap_size);}}void Build_min_heap(int *a,int length){int heap_size=length;for(int i=length/2;i>0;--i)    min_heapify(a,i,heap_size);}void output(int *a,int size){for(int i=0;i<size;++i)cout<<a[i]<<"   ";cout<<endl;}void Heap_Sort(int *a,int size){Build_min_heap(a,size);for(int i=size;i>1;--i)    {    exchange(&a[i],&a[1]);    --size;    min_heapify(a,1,size);    }}int main(){int a[11]={2222,4,1,3,2,16,9,10,14,8,7};Build_min_heap(a,10);output(a+1,10);Heap_Sort(a,10);output(a+1,10);return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昆明市| 友谊县| 石狮市| 印江| 赞皇县| 盱眙县| 祁阳县| 溧水县| 尼勒克县| 仁布县| 绍兴市| 永善县| 南昌县| 福建省| 万荣县| 泰兴市| 郑州市| 南城县| 凌海市| 横山县| 渭源县| 大兴区| 安国市| 镶黄旗| 镇宁| 广昌县| 高唐县| 定远县| 阿坝县| 平和县| 仲巴县| 屯门区| 华安县| 如皋市| 鄯善县| 酉阳| 丹棱县| 新乡县| 岢岚县| 武宣县| 阳城县|