排序算法-哈希排序(HeapSort)

 

#include <iostream>
#include <time.h>
#include <cstdlib>
#define N 10
using namespace std;

//声明建大顶堆函数
void BuildMaxHeap(int * array);
//声明堆排序函数
void HeapSort(int * array);
//声明调整为大顶堆函数
void MaxHeapify(int * array, int n);
//返回堆的数据个数
int HeapSize;

void HeapSort(int * array)
{
	BuildMaxHeap(array);
	for (int i = N - 1; i >= 0; i--)//数组中下标从0  -  N-1
	{
		int temp = array[0];
		array[0] = array[i];
		array[i] = temp;
		HeapSize -= 1;
		MaxHeapify(array, 1);//在堆中,堆顶元素下标从1开始
	}
}

void BuildMaxHeap(int * array)
{
	HeapSize = N;
	for (int i = N / 2; i >= 1; i--)//注意i的取值,堆的高度从1  -  N/2
	{
		MaxHeapify(array, i);
	}
}

void MaxHeapify(int * array, int temp)
{
	int largest;//以temp为顶点的子树的堆顶
	int l = 2 * temp;//求以temp为顶点的子树左儿子
	int r = 2 * temp + 1;//求以temp为顶点的子树右儿子

	if (l <= HeapSize && array[l - 1] > array[temp - 1])//首先判断左儿子是否存在,即l<=HeapSize
	{
		largest = l;
	}
	else{
		largest = temp;
	}

	if (r <= HeapSize && array[r - 1] > array[largest - 1])//首先判断右儿子是否存在,即r<=HeapSize
	{
		largest = r;
	}

	if (largest != temp)
	{
		int t = array[temp - 1];
		array[temp - 1] = array[largest - 1];
		array[largest - 1] = t;
		MaxHeapify(array, largest);//调整为大顶堆
	}
}

/*=====================================================================*/
/*堆排序非递归算法,T(n)=O(nlogn) S(n)=O(1)*/

//本函数调整A[idx]使得A[idx...n]构成大顶堆
void HeapAdjust(int *A, int idx, int n)
{
	int tmp = A[idx];
	for (int j = 2 * idx + 1; j < n; j=2*j+1)
	{
		if (j < n - 1 && A[j] < A[j + 1])
		{
			++j;
		}//if

		if(tmp >= A[j])
			break;

		A[idx] = A[j];
		idx = j;
	}//for
	A[idx] = tmp;
}

int *HeapSort2(int *A, int n)
{
	if (n <= 0)
		return A;

	/*从最后一个根节点开始*/
	for (int i = (n-1) / 2; i >= 0; --i)
	{
		HeapAdjust(A, i, n-1);
	}//for

	for (int i = n - 1; i > 0; --i)
	{
		int tmp = A[0];
		A[0] = A[i];
		A[i] = tmp;

		HeapAdjust(A, 0, i - 1);
	}

	return A;
}

//int main()
//{
//	//声明一个待排序数组
//	int array[N];
//	//设置随机化种子,避免每次产生相同的随机数 
//	srand(time(0));
//	for (int i = 0; i < N; i++)
//	{
//		array[i] = rand() % 101;//数组赋值使用随机函数产生1-100之间的随机数   
//	}
//	cout << "排序前:" << endl;
//	for (int j = 0; j < N; j++)
//	{
//		cout << array[j] << "  ";
//	}
//	cout << endl << "排序后:" << endl;
//	//调用堆排序函数对该数组进行排序   
//	HeapSort(array);
//	for (int k = 0; k < N; k++)
//	{
//		cout << array[k] << "  ";
//	}
//	cout << endl;
//
//	/*非递归堆排序*/
//
//	system("pause");
//	//设置随机化种子,避免每次产生相同的随机数 
//	srand(time(0));
//	for (int i = 0; i < N; i++)
//	{
//		array[i] = rand() % 101;//数组赋值使用随机函数产生1-100之间的随机数   
//	}
//	cout << "排序前:" << endl;
//	for (int j = 0; j < N; j++)
//	{
//		cout << array[j] << "  ";
//	}
//	cout << endl << "排序后:" << endl;
//	//调用堆排序函数对该数组进行排序   
//	HeapSort2(array,N);
//	for (int k = 0; k < N; k++)
//	{
//		cout << array[k] << "  ";
//	}
//	cout << endl;
//	return 0;
//}


 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值