码迷,mamicode.com
首页 > 编程语言 > 详细

C语言 最大堆排序

时间:2015-05-21 22:38:19      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:c语言   数据结构   算法   堆排序   

#include<iostream>
using namespace std;

int left(int i){
	return 2*i;
}
int right(int i){
	return 2*i+1;
}
int parent(int i){
	return i/2;
}
void maxHeapify(int *arr, int length, int i){
	if(arr == 0 || i < 0){
		return ;
	}
	int l = left(i);
	int r = right(i);
	int largest = i;
	if(l < length && arr[l] > arr[largest]){
		largest = l;
	}
	if(r < length && arr[r] > arr[largest]){
		largest = r;
	}
	if(largest != i){
		int temp = arr[i];
		arr[i] = arr[largest];
		arr[largest] = temp;
		maxHeapify(arr, length, largest);
	}
}
void buildMaxHeap(int *arr, int length){
	if(arr == 0 || length <= 0){
		return;
	}
	for(int i=length/2-1; i>=0; i--){
		maxHeapify(arr, length, i);
	}
}
void maxHeapSort(int *arr, int length){
	if(arr == 0 || length <= 0){
		return;
	}
	int temp;
	for(int i=length; i>1; i--){
		temp = arr[i-1];
		arr[i-1] = arr[0];
		arr[0] = temp;
		buildMaxHeap(arr, i-1);
	}
}

int main(){
	int arr[7] = {2, 3, 5, 1, 8, 6, 4};
	maxHeapSort(arr, 7);
	for(int i=0; i<7; i++){
		printf("%d\n", arr[i]);
	}
	return 0;
}

C语言 最大堆排序

标签:c语言   数据结构   算法   堆排序   

原文地址:http://blog.csdn.net/lhbeggar/article/details/45896891

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!