首页 > 其他 > 详细

排序算法 堆排序

时间:2014-05-11 07:36:49      阅读:457      评论:0      收藏:0      [点我收藏+]

堆排序使用最大堆。堆排序:将初始序列构造成最大堆; 第一趟排序,将堆顶元素 A[0] 和堆底元素 A[n-1]进行交换,然后调用AdjustDown对堆顶元素进行向下调整,使剩余的前n-1个元素还是堆。然后使堆顶元素与A[n-2]交换,在进行向下调整。直到最后只剩下堆顶元素。


template <class T>
void AdjustDown(T heap[],int r,int j){
	T temp = heap[r];
	int child = 2 * r + 1;
	while(child < j ){
		child = heap[child] < heap[child+1] ? (child+1) : child;
		if(temp < heap[child]){
			heap[r] = heap[child];
			heap[child] = temp;
			r = child ;
			child = 2 * r + 1;
			temp = heap[r];
		}else
			break;
	}
}
template <class T>
void CreateHeap(T heap[],int n){
	for(int i = n/2 - 1;i>-1;i--)
		AdjustDown(heap,i,n-1);
}
template <class T>
void swap(T &a, T &b){
	T temp = a;
	a = b;
	b = temp;
}
template <class T>
void HeapSort(T A[],int n){
	CreateHeap(A,n);
	for(int i = n-1 ;i > 0 ; i--){
		swap(A[0],A[i]);
		AdjustDown(A,0,i-1);
	}
}

int main()
{
	int A[7] = {99,36,68,72,12,48,02};
	HeapSort(A,7);
	return 0;
}


排序算法 堆排序,布布扣,bubuko.com

排序算法 堆排序

原文:http://blog.csdn.net/luo_xianming/article/details/25483737

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!