数据结构--堆排序

#include <stdio.h>
#include <stdlib.h>

void MaxHeapify(int a[],int length,int i);
void BuildMaxHeapify(int a[],int length);
void HeapSort(int a[],int length);


void main(void)
{
	int i;
	int a[10]={1,3,4,2,1,3,2,19,4,0};
	
	printf("Heapsort algorithm\n");
	HeapSort(a,10);
	for(i=0;i<10;i++)
		printf("%d\n",a[i]);
	while(1);
}

//在i的左右都满足最大堆性质时,使数组中下标为i的节点满足最大堆性质
void MaxHeapify(int a[],int length,int i)
{
	int l = 2*i + 1;  //左节点数组下标
	int r = 2*i + 2;  //右节点数组下表
	int tmp = 0;

	int largest = i;
	if(l < length && a[i] < a[l])
		largest = l;
	if(r < length && a[r] > a[largest])
		largest = r;

	if(largest != i){
		tmp = a[i];
		a[i] = a[largest];
		a[largest] = tmp;

		MaxHeapify(a,length,largest);
	}
	return;
}

//使数组为最大堆,此时a[0]即为最大值
//采用自底向上方法构建最大堆,因为单独的叶节点一定满足最大堆性质
void BuildMaxHeapify(int a[],int length)
{
	int i;
	for(i=length/2-1; i>=0; i--){
		MaxHeapify(a,length,i);
	}
	return;
}

//堆排序算法,首先构造最大堆,然后循环找到最大值
void HeapSort(int a[],int length)
{
	int i,tmp;

	BuildMaxHeapify(a,length); //此时为最大堆,最大值为a[0];
	for(i=length-1; i>0; i--){
		tmp = a[0];
		a[0] = a[i];
		a[i] = tmp;
		length--;
		MaxHeapify(a,length,0);//注意该函数调用条件
	}

}
vs2010已经调试成功。和算法导论描述一致。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕业设计,基于SpringBoot+Vue+MySQL开发的精简博客系统,源码+数据库+毕业论文+视频演示 当下,正处于信息化的时代,许多行业顺应时代的变化,结合使用计算机技术向数字化、信息化建设迈进。以前企业对于博客信息的管理和控制,采用人工登记的方式保存相关数据,这种以人力为主的管理模式已然落后。本人结合使用主流的程序开发技术,设计了一款基于Springboot开发的精简博客系统,可以较大地减少人力、财力的损耗,方便相关人员及时更新和保存信息。本系统主要使用B/S开发模式,在idea开发平台上,运用Java语言设计相关的系统功能模块,MySQL数据库管理相关的系统数据信息,SpringBoot框架设计和开发系统功能架构,最后通过使用Tomcat服务器,在浏览器中发布设计的系统,并且完成系统与数据库的交互工作。本文对系统的需求分析、可行性分析、技术支持、功能设计、数据库设计、功能测试等内容做了较为详细的介绍,并且在本文中也展示了系统主要的功能模块设计界面和操作界面,并对其做出了必要的解释说明,方便用户对系统进行操作和使用,以及后期的相关人员对系统进行更新和维护。本系统的实现可以极大地提高企业的工作效率,提升用户的使用体验,因此在现实生活中运用本系统具有很大的使用价值。 关键词:博客管理;Java语言;B/S结构;MySQL数据库
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值