最大堆的实现---(附完整调试代码)

1.最大堆的数据结构

2.最大堆的创建算法

3.最大堆的插入算法

4.最大堆的删除算法

#include<stdio.h>
#include<stdlib.h>
typedef struct HNode * Heap;
struct HNode{
	int * Data;
	int Size;
	int Capacity;
};
typedef Heap MaxHeap;
typedef Heap MinHeap;

//最大堆的创建 
#define MAXDATA 1000
MaxHeap CreateHeap(int MaxSize){
	MaxHeap H = (MaxHeap)malloc(sizeof(struct HNode));
	H->Data = (int *)malloc ((MaxSize+1)*sizeof(int));
	H->Size=0;
	H->Capacity=MaxSize;
	H->Data[0]=MAXDATA;
	
	return H;
}

//最大堆的插入

bool IsFull(MaxHeap H){
		return (H->Size==H->Capacity);
} 

bool Insert(MaxHeap H,int X){
	int i;
	if(IsFull(H)){
		printf("最大堆已满\n");
		return false;
	}
	i=++H->Size;
	for(;H->Data[i/2]<X;i/=2){
		H->Data[i]=H->Data[i/2];
	}
	H->Data[i]=X;
	return true;
} 

//最大堆的删除
#define ERROR -1
bool IsEmpty(MaxHeap H){
	return (H->Size==0);
} 

int DeleteMax(MaxHeap H){
	int  Parent,Child;
	int MaxItem,X;
	if(IsEmpty(H)){
		printf("最大堆为空\n");
		return false;
	} 
	MaxItem=H->Data[1];
	X=H->Data[H->Size--];
	for(Parent=1;Parent*2<=H->Size;Parent=Child){
		Child=Parent*2;
		if((Child!=H->Size)&&(H->Data[Child]<H->Data[Child]+1))
			Child++;
		if(X>=H->Data[Child]) break;
		else{
			H->Data[Parent]=H->Data[Child];
		}
	}
	H->Data[Parent]=X;
	
	return MaxItem;
}


int main(){
	MaxHeap mp = CreateHeap(10);
	int i,n,z;
	printf("您要插入几个数:");
	scanf("%d",&n);
	for(i=0;i<n;i++){
		scanf("%d",&z);
		Insert(mp,z);
	}
	printf("最大堆遍历:\n");
	for(i=1;i<=mp->Size;i++)
		printf("%d ",mp->Data[i]);
	printf("\n"); 
	printf("最大堆删除后的遍历: \n"); 
	DeleteMax(mp);
	for(i=1;i<=mp->Size;i++)
		printf("%d ",mp->Data[i]);
	return 0;
}

运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值