C++堆排序算法實(shí)例詳解
本文實(shí)例講述了C++堆排序算法。分享給大家供大家參考,具體如下:
堆中元素的排列方式分為兩種:max-heap或min-heap,前者每個(gè)節(jié)點(diǎn)的key都大于等于孩子節(jié)點(diǎn)的key,后者每個(gè)節(jié)點(diǎn)的key都小于等于孩子節(jié)點(diǎn)的key。
由于堆可以看成一個(gè)完全二叉樹,可以使用連續(xù)空間的array來模擬完全二叉樹,簡單原始的實(shí)現(xiàn)如下:
#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);
}
}
//構(gòu)建堆
void buildHeap(int array[],int n){
void heapify(int[],int);
heapsize=n;
//從最小的父節(jié)點(diǎn)開始,進(jìn)行堆化,直到樹根節(jié)點(diǎ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中實(shí)現(xiàn)了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();
//連續(xù)的pop_heap操作,每次的最大值都放在最尾端,最后呈現(xiàn)遞增排序
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++程序設(shè)計(jì)有所幫助。
相關(guān)文章
如何用C++實(shí)現(xiàn)雙向循環(huán)鏈表
本篇文章是對用C++實(shí)現(xiàn)雙向循環(huán)鏈表的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
超詳細(xì)解析C++實(shí)現(xiàn)歸并排序算法
歸并排序是比較穩(wěn)定的排序方法。它的基本思想是把待排序的元素分解成兩個(gè)規(guī)模大致相等的子序列。本文將用C++實(shí)現(xiàn)這一排序算法,需要的可以參考一下2022-09-09
cmake跨平臺(tái)構(gòu)建工具的學(xué)習(xí)筆記
CMake是一個(gè)跨平臺(tái)的安裝/編譯工具,通過CMake我們可以通過簡單的語句來描述所有平臺(tái)的安裝/編譯過程,下面這篇文章主要給大家介紹了關(guān)于cmake跨平臺(tái)構(gòu)建工具的相關(guān)資料,需要的朋友可以參考下2023-02-02

