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

传智播客网站开发全套视频教程seo推广有哪些方式

传智播客网站开发全套视频教程,seo推广有哪些方式,最新网页游戏排行榜2021,宝鸡营销型网站开发公司. 个人主页:晓风飞 专栏:数据结构|Linux|C语言 路漫漫其修远兮,吾将上下而求索 文章目录 前言堆的实现基本操作结构体定义初始化堆(HeapInit)销毁堆(HeapDestroy) 重要函数交换函数(…

在这里插入图片描述在这里插入图片描述

.

个人主页:晓风飞
专栏:数据结构|Linux|C语言
路漫漫其修远兮,吾将上下而求索


文章目录

  • 前言
  • 堆的实现
    • 基本操作
      • 结构体定义
      • 初始化堆(HeapInit)
      • 销毁堆(HeapDestroy)
    • 重要函数
      • 交换函数(Swap)
      • 上浮调整(UpAdd)
      • 下沉调整(DnAdd)
    • 重要操作
      • 向堆中插入元素(HeapPush)
      • 从堆中弹出元素(HeapPop)
  • 堆的应用
  • 完整代码
  • 结语

前言

在计算机科学中,堆(Heap) 是一种非常重要的数据结构,广泛用于各种应用,从数据分析到算法优化,再到系统编程。堆的一个关键特性是其能够快速找到一组数中的最大或最小值。但是,什么是堆?如何在实际编程中实现和使用堆呢?


堆的实现

堆是一种特殊的完全二叉树。在一个最小堆中,每个父节点的值都小于或等于其子节点的值;相反,在一个最大堆中,每个父节点的值都大于或等于其子节点的值。这种属性使得堆能够快速访问、添加和删除其最大或最小元素。

在这里插入图片描述

在这里插入图片描述

基本操作

结构体定义

首先,堆是通过以下结构体定义的:

typedef struct Heap
{HPDataType* a;  // 指向堆数组的指针size_t size;    // 堆当前的大小int capacity;   // 堆的最大容量
} Hp;

这里,HPDataType* a 是一个指向动态分配数组的指针,该数组用于存储堆中的元素。size 表示堆中当前元素的数量,而 capacity是数组的最大容量。

初始化堆(HeapInit)

初始化函数 HeapInit 用于设置堆的初始状态:

// 初始化堆
void HeapInit(Hp* hp)
{assert(hp);  // 确保堆指针有效hp->a = NULL;  // 堆数组指针置空hp->size = 0;  // 初始化堆大小为0hp->capacity = 0;  // 初始化堆容量为0
}

此函数确保堆的开始状态为空,没有分配任何内存,且大小和容量都为零。

销毁堆(HeapDestroy)

为了避免内存泄漏,当堆不再需要时,应该使用 HeapDestroy 函数来释放其占用的内存:

// 销毁堆
void HeapDestroy(Hp* hp)
{assert(hp);  // 确保堆指针有效free(hp->a);  // 释放堆数组内存hp->a = NULL;  // 将堆数组指针置空hp->size = hp->capacity = 0;  // 重置堆大小和容量为0
}

这个函数释放了堆数组 a 的内存,并将指针置空,同时重置大小和容量。

重要函数

交换函数(Swap)

Swap 函数用于交换堆中两个元素的值。这在上浮和下沉调整中非常重要。

// 交换两个元素的值
void Swap(HPDataType* p1, HPDataType* p2)
{HPDataType tmp = 0;  // 临时变量用于交换tmp = *p1;*p1 = *p2;*p2 = tmp;
}

上浮调整(UpAdd)

这个函数通过一个临时变量 tmp 实现了两个元素值的交换。当一个新元素被加入到堆中时,它可能会破坏堆的特性(在最小堆中,所有父节点的值都应该小于其子节点的值)。UpAdd 函数通过将新加入的元素与其父节点进行比较和交换来修复这种情况,直到堆的特性得到恢复或元素到达根位置。

// 上浮调整
void UpAdd(HPDataType* a, HPDataType child)
{int parent = (child - 1) / 2;  // 找到父节点while (child > 0){if (a[child] < a[parent])  // 如果子节点小于父节点{Swap(&a[child], &a[parent]);  // 交换两者child = parent;  // 更新子节点和父节点的位置parent = (child - 1) / 2;}else{break;  // 如果不需要交换,则终止循环}}
}

这个过程被称为“上浮”,因为较小的元素(在最小堆中)浮向堆的顶部。
在这里插入图片描述

下沉调整(DnAdd)

与上浮调整相反,当堆顶元素被移除后,我们需要从堆的顶部开始将新的根元素下移,以保持堆的特性。这是通过将父节点与其子节点比较并在必要时进行交换来实现的。

// 下沉调整
void DnAdd(HPDataType* a, HPDataType parent, int size)
{int child = parent * 2 + 1;  // 找到左子节点while (child < size){if (child + 1 < size && a[child + 1] < a[child])  //检查右子节点是否存在,以及比较左右两个子节点的值{child++;  // 选择较小的子节点}if (a[child] < a[parent]){Swap(&a[child], &a[parent]);  // 交换父子节点parent = child;  // 更新父子节点的位置child = parent * 2 + 1;}else{break;  // 如果不需要交换,则终止循环}}
}

这个过程被称为“下沉”,因为较大的元素(在最小堆中)下沉到堆的底部。
在这里插入图片描述

重要操作

向堆中插入元素(HeapPush)

插入操作是堆的核心功能之一。HeapPush 函数首先检查是否需要扩展堆的容量,然后将新元素添加到堆的末尾,并进行上浮调整以保持堆的特性:

// 向堆中插入元素
void HeapPush(Hp* hp, HPDataType x)
{assert(hp);  // 确保堆指针有效if (hp->size == hp->capacity){// 如果堆已满,扩大容量int newcapacity = hp->capacity == 0 ? 4 : hp->capacity * 2;HPDataType* tmp = (HPDataType*)realloc(hp->a, sizeof(HPDataType) * newcapacity);if (tmp == NULL){perror("realloc fail");  // 内存分配失败exit(-1);}hp->a = tmp;hp->capacity = newcapacity;}hp->a[hp->size] = x;  // 插入元素hp->size++;  // 堆大小增加UpAdd(hp->a, hp->size - 1);  // 上浮调整
}

从堆中弹出元素(HeapPop)

HeapPop 函数移除堆顶元素,这通常是堆中的最小或最大值。在移除元素后,它执行下沉调整以保持堆的特性:

// 从堆中弹出元素
void HeapPop(Hp* hp)
{assert(hp);  // 确保堆指针有效assert(hp->size > 0);  // 确保堆非空Swap(&hp->a[0], &hp->a[hp->size - 1]);  // 交换堆顶和堆底元素hp->size--;  // 减小堆大小DnAdd(hp->a, 0, hp->size);  // 下沉调整
}

上浮和下沉调整
上浮(UpAdd)和下沉(DnAdd)调整是维护堆特性的关键操作。上浮调整用于在添加新元素后恢复堆的特性,而下沉调整则在移除顶部元素后用于恢复堆的特性。

堆的应用

堆在多种场景中都非常有用。例如,在优先队列、堆排序、图算法(如Dijkstra的最短路径算法)中,堆结构都扮演着核心角色。它能够优化这些算法的性能,特别是在处理大数据集时。

如何使用堆?
使用堆的一个典型例子是维护动态数据集的最小或最大元素。以下是使用C语言实现的堆如何工作的一个简单示例:

int main() {int a[] = {4, 6, 2, 1, 5, 8, 2, 9};Hp hp;HeapInit(&hp);// 将数组元素插入堆中for (int i = 0; i < sizeof(a) / sizeof(int); ++i) {HeapPush(&hp, a[i]);}// 弹出并打印堆顶元素,直到堆为空while (!HeapEmpty(&hp)) {printf("%d ", HeapTop(&hp));HeapPop(&hp);}return 0;
}

也可以用堆输出数组a中最大的前三个数

	int k = 3;while (k--){printf("%d\n", HeapTop(&hp));HeapPop(&hp);}

完整代码

可以来我的github参观参观,看完整代码
路径点击这里–>数据结构堆的实现练习

结语

希望这篇文章能够帮助您清晰地理解堆的结构和功能,并鼓励您在未来的项目中尝试和探索它。理解数据结构的关键不仅在于记住它们的运作方式,而且在于知道何时以及如何使用它们。无论您是一位经验丰富的程序员还是刚开始编程之旅的新手,掌握数据结构总是一项宝贵的技能。因此,拿起您的编程工具,开始构建、优化,最重要的是,享受编程带来的无限可能吧!

http://www.hengruixuexiao.com/news/38594.html

相关文章:

  • 网站安全检测漏洞扫描风险等级分布太原关键词优化软件
  • 网站用户黏度表现在收录入口在线提交
  • 网站建设有什么需求抖音seo推广外包公司好做吗
  • 生日礼物自己做网站知名的搜索引擎优化
  • 专业网站建设定制公司产品线下推广方式都有哪些
  • 做网站能挣钱么广告软文外链平台
  • 做网站威海网页设计模板网站免费
  • 南昌专门做网站生活中的网络营销有哪些
  • 网站后台 批量上传app排名优化公司
  • 打开一个网站搜索页面跳转js百度站长工具怎么查排名
  • 高端品牌网站设计关键词优化公司网站
  • 做JSP网站买什么书小程序源码网
  • 建设网站平台需要的设备排行榜前十名
  • 手机网站后台源码小时seo
  • 这么自己做网站深圳seo优化方案
  • 政府网站 banner 源码网络营销策划书总结
  • 外贸商做英文网站的目的石家庄百度关键词优化
  • 如何建设电子商务网站软文推广渠道主要有
  • 旅游网站开发景点数据库googleplay官方下载
  • 网站后台管理系统如何安装搜索引擎优化方法有哪些
  • 旅游营销型网站建设成都新一轮疫情
  • 专业积分商城网站建设吸引顾客的营销策略
  • 企业网站备案需要什么资料seo公司杭州
  • 网站https认证怎么做如何自己建个网站
  • 肇庆建设银行招聘网站微营销系统
  • 网站平台建设属于固定资产吗搜索引擎广告投放
  • 专业的网站首页建设公司设计网络推广方案
  • 专门做护肤品网站计算机培训班
  • 深圳网站定制深圳网站建设公司漯河网络推广哪家好
  • 怎么做谷歌这样的网站吗怎么做好销售