数据结构——最大堆(最小堆)问题

堆,是利用完全二叉树来维护一组数据,经行相关操作。

最大堆就是所有父节点都比子节点要大,同理,最小堆就是所有父节点都比子节点要小。


//最大堆的操作
#include "stdafx.h"
#include <iostream>
#include <stdlib.h>
#define MaxSize 100
#define MaxData 1000
using namespace std;
template <class T>
struct HeapTree
{
	T *elements;   //根节点里面包含多个子元素
	int Size;    //表示有多少个子元素
	int Capacity;
};
template <class T>
class Heap
{
private:
	HeapTree<T> *root;
	HeapTree<T> *Creat();   //创建空的堆
public:
	Heap() { root = Creat(); }
	void Insert(T item);    //插入法完成堆的建立
	void Print();
};
template <class T>
HeapTree<T>  *Heap<T>::Creat()   //创建空的堆
{
	root = new HeapTree<T>;
	root->elements = new T[MaxSize + 1];
	root->Size = 0;
	root->Capacity = MaxSize;   //堆的最大量为MaxSize
	root->elements[0] = MaxData;   //设置一个堆中的最大数据,方便比较
	return root;
}
template <class T>
void Heap<T>::Insert(T item)
{
	int i;
	if (root->Size > MaxSize)
	{
		printf("最大堆已满");
		return;
	}
	i = ++root->Size;
	for (; root->elements[i / 2]<item; i /= 2)   //由子节点找到父节点,item与父节点比较
	{
		root->elements[i] = root->elements[i / 2];   //子节点下移一层
	}
	root->elements[i] = item;   //找到位置,插入item
}
template <class T>
void Heap<T>::Print()
{
	int i;
	for (i = 1; i <= root->Size; i++)
		cout << root->elements[i] << " ";
}
int main()
{
	Heap<int> H;
	int a[10] = { 15,389,2,77,5,1,3,64,14,9 };
	for (int i = 0; i < 10; i++)
		H.Insert(a[i]);
	H.Print();
    system("pause");
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值