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

首頁 > 學院 > 開發(fā)設計 > 正文

建最小堆min_heap_sort

2019-11-14 12:35:38
字體:
供稿:網(wǎng)友

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

#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;}
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 安溪县| 抚州市| 通山县| 华阴市| 文安县| 武冈市| 河西区| 栾城县| 扎赉特旗| 淮阳县| 天柱县| 安岳县| 万源市| 东安县| 宁陵县| 怀仁县| 泰宁县| 阿瓦提县| 江陵县| 洪泽县| 黎平县| 城市| 庆云县| 安龙县| 景泰县| 霍山县| 青阳县| 徐州市| 浮梁县| 都江堰市| 沈丘县| 庄河市| 屯门区| 阳西县| 沈阳市| 岳阳县| 清远市| 舞钢市| 梧州市| 南平市| 长治县|