堆-c++

/**********************************************************************
*版权所有 (C)2014, cy。
*
*文件名称:堆.cpp 
*内容摘要:无
*其它说明:无
*当前版本: V1.0
*作    者:cheng yang
*完成日期: 20140624
*
*  版本       修改时间     修改人           修改内容
********************************************************************
*   V1.0        20140624    cy			   创建
**********************************************************************/
#include <iostream>
using namespace std;

//字段最大长度
const int MAXSIZE = 10000;
int a[MAXSIZE] = {0};
int heapsize = 0;

//函数声明
inline void swap(int i , int j)
{
	int temp = a[i];
	a[i] = a[j];
	a[j] = temp;

}

//获得i节点的父亲节点下标
inline int Parent(int i) 
{
	return i >> 1;
}

//左孩子节点的下标
inline int Left(int i)
{
	return i << 1;
}

//右孩子节点的下标
inline int Right(int i)
{
	return (i << 1) + 1;
}


/**********************************************************************
*功能描述:保持堆的性质
*输入参数:数组a[]的下标
*输出参数:无
*返回值:无 
*其它说明:无
*修改日期        版本号            修改人         修改内容
* --------------------------------------------------------------
* 
***********************************************************************/
void MaxHeapify(int i)
{
	int left = Left(i);
	int right= Right(i);
	int largest = 0;
	if (left <= heapsize && a[left] > a[i])
	{
		largest = left;
	}
	else
	{
		largest = i;
	}
	if (right <= heapsize && a[right] > a[largest])
	{
		largest = right;
	}
	if (largest != i)
	{
		swap(i, largest);
		MaxHeapify(largest);
	}
}

/**********************************************************************
*功能描述:建堆
*输入参数:指向全局数组的指正 arr*
堆的大小 n
*输出参数:无
*返回值:无
*其它说明:无
*修改日期        版本号            修改人         修改内容
* --------------------------------------------------------------
*
***********************************************************************/
void BuildHeapify(int *arr, const int n)
{
	heapsize = n;
	for (int i = heapsize / 2; i >= 0; i--)
	{
		MaxHeapify(i);
	}
}

/****************************************************************
*功能描述:  主函数                                             *
*输入参数:  无                                                 *
*输出参数:  无                                                 *
*返回值  :无                                                 *
*其他说明:  无                                                 *
*修改日期        版本号       修改人        修改内容
* -------------------------------------------------------------------------------
* 
****************************************************************/
int main()
{	
	int i = 0;
	while (cin >> a[i++])//为什么i会比实际输入的多出2个,输入3个数(a[0]--a[2]),可i=4;??

	BuildHeapify(a, i-2);
	for (int j =i-2 ; j >= 0; j--)
	{
		cout << a[0] << endl;
		swap(0, j);
		heapsize--;
		MaxHeapify(0);
	}

	system("pause");
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值