最小堆的实现---(附完整运行代码)

1.最小堆的数据结构

2.最小堆的创建算法

3.最小堆的插入算法

4.最小堆的删除算法

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

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

//最小堆的插入

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

bool Insert(MinHeap 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(MinHeap H){
	return (H->Size==0);
} 

int DeleteMin(MinHeap 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(){
	MinHeap 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"); 
	DeleteMin(mp);
	for(i=1;i<=mp->Size;i++)
		printf("%d ",mp->Data[i]);
	return 0;
}

运行结果:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值