当前位置: 首页 > news >正文

【数据结构】堆的创建

Heap.h

#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
#include<assert.h>//创建堆结构体
typedef int HPDateType;
typedef struct Heap
{HPDateType* a;int size;int capacity;
}HP;//堆的初始化
void HPInit(HP* php);//堆的销毁
void HPDestroy(HP* php);//交换
void Swap(HPDateType* p1, HPDateType* p2);//向上调整
void AdjustUp(HPDateType* a, int child);//堆的插入
void HPPush(HP* php, HPDateType x);//向下调整
void AdjustDown(HPDateType* a, int n, int parent);//堆的删除(删除根部数据)
void HPPop(HP* php);//取堆顶的数据
HPDateType HPTop(HP* php);//堆的数据个数
int HPSize(HP* php);//判断堆是否为空
bool HPEmpty(HP* php);

Heap.c

#include"Heap.h"//堆的初始化
void HPInit(HP* php)
{assert(php);php->a = NULL;php->size = php->capacity = 0;
}//堆的销毁
void HPDestroy(HP* php)
{assert(php);free(php->a);php->a = NULL;php->size = php->capacity = 0;free(php);php = NULL;
}//交换
void Swap(HPDateType* p1, HPDateType* p2)
{HPDateType* tmp = *p1;*p1 = *p2;*p2 = tmp;
}//向上调整
void AdjustUp(HPDateType* a, int child)
{int parent = (child - 1) / 2;//小堆(根为最小值)while (parent >= 0 && child != 0){if (a[parent] > a[child]){Swap(&a[parent], &a[child]);child = parent;parent = (child - 1) / 2;}else{break;}}大堆(根为最小值)//while (parent >= 0 && child != 0)//{//	if (a[parent] < a[child])//	{//		Swap(&a[parent], &a[child]);//		child = parent;//		parent = (child - 1) / 2;//	}//	else//	{//		break;//	}//}
}//堆的插入
void HPPush(HP* php, HPDateType x)
{assert(php);//开辟空间if (php->size == php->capacity){int newcapacity = php->capacity == 0 ? 4 : php->capacity * 2;HPDateType* tmp = (HPDateType*)realloc(php->a, sizeof(HPDateType) * newcapacity);if (tmp == NULL){perror("realloc fail:");exit(1);}php->a = tmp;php->capacity = newcapacity;}//添加数据php->a[php->size++] = x;//向上调整建堆AdjustUp(php->a, php->size - 1);
}//向下调整
void AdjustDown(HPDateType* a, int n, int parent)
{int child = parent * 2 + 1;//小堆while (child < n){if (child + 1 < n && a[child] > a[child + 1]){child++;}if (a[parent] > a[child]){Swap(&a[parent], &a[child]);parent = child;child = (parent + 1) * 2;}else{break;}}大堆//while (child < n)//{//	if (child + 1 < n && a[child] < a[child + 1])//	{//		child++;//	}//	if (a[parent] < a[child])//	{//		Swap(&a[parent], &a[child]);//		parent = child;//		child = (parent + 1) * 2;//	}//	else//	{//		break;//	}//}
}//堆的删除(删除根部数据)
void HPPop(HP* php)
{assert(php);assert(php->size > 0);//先将根部数据于最后一个数据互换,并删除最后一个数据Swap(&php->a[0], &php->a[php->size - 1]);php->size--;//向下调整AdjustDown(php->a, php->size, 0);
}//取堆顶的数据
HPDateType HPTop(HP* php)
{assert(php);assert(php->size > 0);return php->a[php->size - 1];
}//堆的数据个数
int HPSize(HP* php)
{assert(php);return php->size;
}//判断堆是否为空
bool HPEmpty(HP* php)
{assert(php);return HPSize(php);
}
http://www.lryc.cn/news/464745.html

相关文章:

  • Linux下Git操作
  • 缺失d3dx9_42.dll如何修复,d3dx9_42.dll故障的6种修复方法分享
  • 深入理解Android WebView的加载流程与事件回调
  • 机器视觉相机自动对焦算法
  • StarTowerChain:开启去中心化创新篇章
  • SpringCloudStream使用StreamBridge实现延时队列
  • MATLAB中head函数用法
  • golang 基本数据类型
  • 各种查询sql介绍
  • Guava防击穿回源-异步防击穿
  • 人工智能正在扼杀云计算的可持续性
  • C# 条形码、二维码标签打印程序
  • 嵌入式入门学习——6Protues点亮数码管,认识位码和段码,分辨共阴还是共阳(数字时钟第一步)
  • poisson过程——随机模拟(Python和R实现)
  • 100 种下划线 / 覆盖层动画 | 终极 CSS(层叠样式表)集合
  • 华为ICT大赛2024-2025网络赛道考试分析
  • linux 效率化 - 输入法 - fcitx5
  • YOLOv11改进策略【卷积层】| 替换骨干网络 CVPR-2024 RepViT 轻量级的Vision Transformers架构
  • 一天认识一个硬件之路由器
  • 【scene_manager】与 MoveIt 机器人的规划场景进行交互
  • 数据结构单向链表的插入和删除(一)
  • 鸿蒙网络编程系列30-断点续传下载文件示例
  • 深入拆解TomcatJetty(二)
  • 单元化架构,分布式系统的新王!
  • 【力扣打卡系列】滑动窗口与双指针(乘积小于K的子数组)
  • 浅谈微前端【qiankun】的应用
  • 【JavaEE】——四次挥手,TCP状态转换,滑动窗口,流量控制
  • D42【python 接口自动化学习】- python基础之函数
  • GitLab 老旧版本如何升级?
  • 现今 CSS3 最强二维布局系统 Grid 网格布局