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

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

建最小堆min_heap_sort

2019-11-14 12:36:03
字體:
來源:轉載
供稿:網友

建最小堆與最大堆方法相同 只要改動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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 来安县| 邻水| 西乡县| 商丘市| 改则县| 崇明县| 德格县| 富裕县| 威信县| 闵行区| 蓝田县| 花莲县| 白沙| 宁陕县| 新兴县| 登封市| 台中县| 城口县| 额敏县| 巴塘县| 南开区| 金溪县| 巴马| 金山区| 阳谷县| 阿勒泰市| 昌乐县| 化州市| 博白县| 新建县| 沁阳市| 页游| 米林县| 建德市| 神木县| 宿迁市| 诸暨市| 抚顺县| 乳山市| 江永县| 磐安县|