C语言实现堆的简单操作的示例代码

目录
  • 一、堆的概念
  • 二、堆的实现
  • 三、堆的代码实现

一、堆的概念

(1)定义

如果有一个关键码的集合K = {k0,k1, k2,…,kn-1},把它的所有元素按完全二叉树的顺序存储方式存储在一个一维数组中,并满足:Ki <= K2i+1 且 Ki<= K2i+2 (Ki >= K2i+1 且 Ki >= K2i+2) i = 0,1,2…,则称为小堆(或大堆)。将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆。

(2)性质

1.堆中某个节点的值总是不大于或不小于其父节点的值;

2.堆总是一棵完全二叉树。

(3)小根堆示例图

二、堆的实现

(1)堆的创建

例如:int a[ ] = {1,5,3,8,7,6};

a.初始化堆

b.交换3 和 6

c.交换5 和 8

d.交换1 和 8

调整1和8的位置,8的左子树构成的结构被破坏,每一次调整元素的时候都有可能破坏其子堆的结构。

(2)堆的插入

先将数字插入到数组的尾部,然后进行向上调整算法,直到满足堆。

例如:在一个堆中插入80

(3)堆的删除

删除堆是删除堆顶的数据,将堆顶的数据根最后一个数据一换,然后删除数组最后一个数据,再进行向下调整算法。

三、堆的代码实现

#include"common.h"
#define HeapDataType int
typedef struct Heap
{
	HeapDataType *base;
	int  capacity;
	int  size;
}Heap;
void HeapInit(Heap *php, int n);
void MinHeapInsert(Heap *php, HeapDataType x);
HeapDataType MinHeapRemove(Heap *php);
bool HeapEmpty(Heap *php);
void HeapPrint(Heap *php);
void HeapSort(Heap *php);
void AdjustUp(HeapDataType *base, int start);
void AdjustDown(HeapDataType *base, int start, int n);
void HeapInit(Heap *php, int n)
{
	assert(php != NULL);
	php->base = (HeapDataType*)malloc(sizeof(HeapDataType) * n);
	assert(php->base != NULL);
	php->capacity = n;
	php->size = 0;
}
bool HeapEmpty(Heap *php)
{
	assert(php != NULL);
	return php->size == 0;
}
void MinHeapInsert(Heap *php, HeapDataType x)
{
	assert(php != NULL);
	if(php->size < php->capacity)
	{
		php->base[php->size] = x;
		AdjustUp(php->base, php->size);
		php->size++;
	}
}

HeapDataType MinHeapRemove(Heap *php)
{
	assert(php != NULL);
	assert(php->size > 0);
	int heaptop_val = php->base[0];
	php->size--;
	php->base[0] = php->base[php->size];
	AdjustDown(php->base, 0, php->size);
	return heaptop_val;
}

void HeapPrint(Heap *php)
{
	for(int i=0; i<php->size; ++i)
		printf("%d ", php->base[i]);
	printf("\n");
}

void AdjustUp(HeapDataType *base, int start)
{
	int j = start;
	int i = (j-1)/2;

	HeapDataType tmp = base[j];

	while(j > 0)
	{
		if(tmp < base[i])
		{
			base[j] = base[i];
			j = i;
			i = (j-1)/2;
		}
		else
			break;
	}
	base[j] = tmp;
}

void AdjustDown(HeapDataType *base, int start, int n)
{
	int i = start;
	int j = 2*i + 1;
	while(j < n)
	{
		if(j+1<n && base[j]>base[j+1])
			j++;
		if(base[i] > base[j])
		{
			Swap(&base[i], &base[j]);
			i = j;
			j = 2*i + 1;
		}
		else
			break;
	}
}
void HeapSort(Heap *php, int ar[], int n)
{
	for(int i=0; i<n; ++i)
		php->base[i] = ar[i];
	php->size = n;
	int curpos = n/2 - 1;
	while(curpos >= 0)
	{
		AdjustDown(php->base, curpos, n);
		curpos--;
	}

	int end = n-1;
	while(end > 0)
	{
		Swap(&php->base[0], &php->base[end]);
		AdjustDown(php->base, 0, end);
		end--;
	}

	int k = php->size - 1;
	for(int i=0; i<n; ++i)
	{
		ar[i] = php->base[k--];
	}
}

到此这篇关于C语言实现堆的简单操作的示例代码的文章就介绍到这了,更多相关C语言 堆内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解C语言之堆栈

    目录 一.何为堆栈? 二.思维导图 三.代码 1.顺序堆栈 2.链式堆栈 总结 一.何为堆栈? a.堆栈是一种特殊的线性表 b.堆栈的数据元素以及数据元素间的逻辑关系和线性表完全相同,其不同点是:线性表允许在任意位置插入和删除数据元素,但堆栈只允许在固定一端进行插入和删除数据元素,所以栈又称为"先进后出"(FILO)或"后进先出"(LIFO)的线性表 c.堆栈中允许进行插入和删除数据元素的一端称为栈顶,另一端称为栈底 d.堆栈的插入操作通常称为进栈或入栈:堆栈的删除

  • C语言的堆串操作详解

    目录 一.堆串概念. 二.基本操作. 三.运行: 总结 一.堆串概念. 与定长顺序穿的存储结构类似,都是用一组地址连续的存储单元存储串的字符序列,不同的是堆串的存储空间是动态分配的,只要存储空间分配成功,就不会担心串在插入或者连接时候出现截断的情况. malloc(),free(),realloc()  这三个函数用来对动态存储进行操作. 二.基本操作. #include<stdio.h> #include<stdlib.h> #include<string.h> #d

  • C语言实现大顶堆的示例代码

    目录 堆的实现 1.堆结构 2.堆的种类 3.大顶堆代码实现 堆的实现 1.堆结构 逻辑结构上类似于 一棵 “树” 2.堆的种类 大顶堆结构: 一种特殊的树:其每个子节点均比母节点要小 小顶堆结构: 同理:其每个子节点均比母节点要大 结构图示: 3.大顶堆代码实现 这里实现堆 用循序表的方式 ①初始化: typedef int Heaptype; typedef struct Heap { Heaptype* head; int size; //记录堆总容量 int capacity; //记录

  • C语言数据结构之堆排序详解

    目录 1.堆的概念及结构 2.堆的实现 2.1堆的向下调整算法 2.2堆的向上调整算法 2.3建堆(数组) 2.4堆排序 2.5堆排序的时间复杂度 1.堆的概念及结构 如果有一个关键码的集合K = {k0,k1, k2,…,kn-1},把它的所有元素按完全二叉树(二叉树具体概念参见——二叉树详解)的顺序存储方式存储在一个一维数组中,并满足:Ki <= K2i+1 且 Ki<= K2i+2 (Ki >= K2i+1 且 Ki >= K2i+2) i = 0,1,2…,则称为小堆(或大

  • C语言堆栈入门指南

    C语言堆栈入门指南 在计算机领域,堆栈是一个不容忽视的概念,我们编写的C语言程序基本上都要用到.但对于很多的初学着来说,堆栈是一个很模糊的概念.堆栈:一种数据结构.一个在程序运行时用于存放的地方,这可能是很多初学者的认识,因为我曾经就是这么想的和汇编语言中的堆栈一词混为一谈.我身边的一些编程的朋友以及在网上看帖遇到的朋友中有好多也说不清堆栈,所以我想有必要给大家分享一下我对堆栈的看法,有说的不对的地方请朋友们不吝赐教,这对于大家学习会有很大帮助. 首先在数据结构上要知道堆栈,尽管我们这么称呼它,

  • C语言实现堆的简单操作的示例代码

    目录 一.堆的概念 二.堆的实现 三.堆的代码实现 一.堆的概念 (1)定义 如果有一个关键码的集合K = {k0,k1, k2,…,kn-1},把它的所有元素按完全二叉树的顺序存储方式存储在一个一维数组中,并满足:Ki <= K2i+1 且 Ki<= K2i+2 (Ki >= K2i+1 且 Ki >= K2i+2) i = 0,1,2…,则称为小堆(或大堆).将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆. (2)性质 1.堆中某个节点的值总是不大于或不小

  • C语言数据结构之栈简单操作

    C语言数据结构之栈简单操作 实验: 编写一个程序实现顺序栈的各种基本运算,并在此基础上设计一个主程序,完成如下功能: (1)初始化顺序栈 (2)插入元素 (3)删除栈顶元素 (4)取栈顶元素 (5)遍历顺序栈 (6)置空顺序栈 分析: 栈的顺序存储结构简称为顺序栈,它是运算受限的顺序表. 对于顺序栈,入栈时,首先判断栈是否为满,栈满的条件为:p->top= =MAXNUM-1,栈满时,不能入栈; 否则出现空间溢出,引起错误,这种现象称为上溢. 出栈和读栈顶元素操作,先判栈是否为空,为空时不能操作

  • Django+mysql配置与简单操作数据库实例代码

     第一步:下载mysql驱动 cmd进入创建好的django项目目录:使用命令 pip install mysqlclient 等待安装成功! 第二步:在settings.py中配置mysql连接参数(没有mysql的先装mysql) DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': '数据库名(你得先在mysql中创建数据库)', 'USER':'mysql用户名(如root)', 'PASSWOR

  • Go语言操作数据库及其常规操作的示例代码

    Go操作MySQL 安装: go get -u github.com/go-sql-driver/mysql GO语言的操作数据库的驱动原生支持连接池, 并且是并发安全的 标准库没有具体的实现 只是列出了一些需要的第三方库实现的具体内容 //第一次连接MySQL成功 package main import ( "database/sql" _ "github.com/go-sql-driver/mysql" // _想当于init()初始化 "log&qu

  • C语言编程C++旋转字符操作串示例详解

    目录 旋转字符串 字符串左旋 题前认知: 暴力移位: 三步翻转: 判断字符串旋转 题前认知 字符串追加判断 旋转字符串 字符串左旋 实现一个函数,可以左旋字符串中的k个字符. 例如: ABCD左旋一个字符得到BCDA ABCD左旋两个字符得到CDAB 题前认知: 一个字符串如果就定死了.eg:char arr[]="dfdf"什么的那多没意思,一点都没有人机交互的感觉,(虽然现在人机交互适合个体,不适合集群,但也是比死板的定死字符串舒服) 所以字符串得是我们可输入的,才有可玩性,玩的不

  • Python Learning 列表的更多操作及示例代码

    遍历列表-for循环 列表中存储的元素可能非常多,如果想一个一个的访问列表中的元素,可能是一件十分头疼的事.那有没有什么好的办法呢?当然有!使用 for循环 假如有一个食物名单列表,通过 for循环 将列表中的食物名称都打印出来 # 定义一个食物名单列表 foods = ['potato', 'tomato', 'noodles', 'apple', 'pizza'] # 循环访问foods列表 for food in foods: print(food) 输出: potato  tomato 

  • C# 利用Selenium实现浏览器自动化操作的示例代码

    概述 Selenium是一款免费的分布式的自动化测试工具,支持多种开发语言,无论是C. java.ruby.python.或是C# ,你都可以通过selenium完成自动化测试.本文以一个简单的小例子,简述C# 利用Selenium进行浏览器的模拟操作,仅供学习分享使用,如有不足之处,还请指正. 涉及知识点 要实现本例的功能,除了要掌握Html ,JavaScript,CSS等基础知识,还涉及以下知识点: log4net:主要用于日志的记录和存储,本例采用log4net进行日志记录,便于过程跟踪

  • C语言实现线性动态(单向)链表的示例代码

    目录 什么是链表 为什么不用结构体数组 链表的操作 创建表 删除元素 插入元素 代码及运行结果 什么是链表 链表是数据结构里面的一种,线性链表是链表的一种,线性链表的延伸有双向链表和环形链表.在编程语言中优化数据结构可以在处理大数据时大大降低程序的空间复杂性和时间复杂性.这里我只用一个简单的例子——线性单向链表为例,说明C语言是如何实现该结构的. 链表的元素是由结构体来实现struct table *p.结构体中有一个成员是结构体指针struct table *next,而这个结构体指针的类型和

  • C语言实现ATM自动取款机系统的示例代码

    目录 基于C语言的ATM自动取款机系统项目设计与开发 一.ATM自动取款机系统功能分析与介绍 二.开发ATM自动取款机系统的工具以及创建项目的过程 ATM自动取款机系统的设计与开发的步骤 一.设计登入页面的显示功能 二.设计登入页面退出功能 三.设计登入页面登入和系统主页面显示的功能 四.设计主页面修改用户密码的功能 五.设计主页面查询用户余额的功能 六.设计主页面用户取款的功能 七.设计主页面用户存款的功能 八.返回登入页面的功能 总结 基于C语言的ATM自动取款机系统项目设计与开发 一.AT

  • C++ I/O文件读写操作的示例代码

    IO: 向设备输入数据和输出数据C++的IO流 c++中,必须通过特定的已经定义好的类, 来处理IO(输入输出) 文件流: 对文件进行读写操作 头文件: 类库: ifstream 对文件输入(读文件) ofstream 对文件输出(写文件) fstream 对文件输入或输出 //写文件 #include <fstream> #include <iostream> #include <string> using namespace std; int main() { st

随机推荐