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

杭州网站建设很 棒网址大全123

杭州网站建设很 棒,网址大全123,电子商务网站建设试题,食品网站建设1.简介 堆是一种特殊的数据结构,通常用于实现优先队列。堆是一个可以被看作近似完全二叉树的结构,并且具有一些特殊的性质,根据这些性质,堆被分为最大堆(或者大根堆,大顶堆)和最小堆两种。 2.…

1.简介


堆是一种特殊的数据结构,通常用于实现优先队列。堆是一个可以被看作近似完全二叉树的结构,并且具有一些特殊的性质,根据这些性质,堆被分为最大堆(或者大根堆,大顶堆)和最小堆两种。
在这里插入图片描述

2.基本性质


  1. 完全二叉树结构:堆必须是一棵完全二叉树,即除了最底层,其他层都是满的,而且最底层的节点都尽量靠左排列,最后一行元素之间不可以有间隔。
  2. 堆序性质: 堆分为最大堆和最小堆两种。在最大堆中,任意节点的值都大于或等于其子节点的值;在最小堆中,任意节点的值都小于或等于其子节点的值。

3.节点下标间的规律


因为堆是一棵完全二叉树若父节点的下标为i,则左子节点下标为2i+1,右子节点下标为2i+2,这个规律会在算法排序中经常使用。

4.堆的基本操作


上滤(Percolate Up)

上滤是指在堆中插入新元素后,通过一系列的比较和交换操作将该元素上移到合适的位置,以保持堆的堆序性。通常用于最小堆和最大堆中。

步骤:

  1. 将新元素插入到堆的末尾(底部)。
  2. 比较该元素与其父节点的值。
  3. 如果该元素的值比父节点的值更小(对于最小堆)或更大(对于最大堆),则交换它们。
  4. 重复步骤2和步骤3,直到满足堆的性质为止。
下滤(Percolate Down)

下滤是指在删除堆顶元素后,通过一系列的比较和交换操作将堆的最后一个元素(通常是堆底元素)移到堆顶,并将其下移到合适的位置,以保持堆的堆序性。

步骤:

  1. 将堆的最后一个元素(通常是堆底元素)移到堆顶。
  2. 比较该元素与其子节点中较小(对于最小堆)或较大(对于最大堆)的一个。
  3. 如果该元素的值比子节点的值更小(对于最小堆)或更大(对于最大堆),则交换它们。
  4. 重复步骤2和步骤3,直到满足堆的性质为止。
应用场景:
  • 上滤: 通常在插入新元素时使用,确保新元素的插入不破坏堆的性质。
  • 下滤: 通常在删除堆顶元素后使用,以恢复堆的性质。
堆化(Heapify)

堆化(Heapify)是指将一个无序的序列转换成一个堆,可以是最小堆或最大堆。堆化过程可以分为两种:自底向上堆化(Bottom-Up Heapify)和自顶向下堆化(Top-Down Heapify)。

自底向上堆化(Bottom-Up Heapify):

自底向上堆化是从序列的最后一个非叶子节点开始,逐步向前处理每个节点,使得以该节点为根的子树成为一个堆。该方法保证了子树堆化后,整个序列也是一个堆。

步骤:

  1. 从序列的最后一个非叶子节点开始(通常是 n/2-1,其中 n 是序列的长度)。

  2. 对每个非叶子节点,与其子节点比较,如果不满足堆的性质,则进行交换。

  3. 重复上述步骤,直到处理完整个序列。

自顶向下堆化(Top-Down Heapify):

自顶向下堆化是从序列的第一个元素开始,逐步向后处理每个节点,使得以该节点为根的子树成为一个堆。该方法保证了每个节点都满足堆的性质。

步骤:

  1. 从序列的第一个元素开始。

  2. 对每个节点,与其子节点比较,如果不满足堆的性质,则进行交换。

  3. 重复上述步骤,直到处理完整个序列。

应用场景:

  • 建堆: 堆化是建立堆的关键步骤,可以在 O(n) 的时间复杂度内将一个无序序列转化为堆。
  • 堆排序: 在堆排序算法中,首先对待排序序列进行堆化,然后反复取出堆顶元素,直到堆为空,实现排序。
  • 优先队列: 堆被广泛应用于实现优先队列,堆化操作确保队列中优先级最高的元素位于队首。

推荐观看: 【从堆的定义到优先队列、堆排序】 10分钟看懂必考的数据结构——堆

http://www.shuangfujiaoyu.com/news/46252.html

相关文章:

  • 微网站开发平台 知乎网站seo优化建议
  • 什么网站可以在线做考教师岗位的题百度排名优化专家
  • 自己做项目的网站即时热榜
  • 国内网站建设阿里云百度精准营销获客平台
  • c2c商城网站建设二次开发查网站域名
  • 北京建设集团网站seo网站推广收费
  • 宁波网站建设哪里好外贸seo网站推广
  • 福建省委常委百度seo招聘
  • 哪些网站做的好看的国内10大搜索引擎
  • 做网站也分内存大小的吗腾讯企点怎么注册
  • 自己做的网站让别人看到武汉排名seo公司
  • 深圳正规制作网站搜狗seo
  • 重庆点优建设网站公司吗什么软件可以刷网站排名
  • 青岛网站有限公司广州seo网站排名
  • 在百度里面做网站要多少钱bing搜索国内版
  • 网站开发好吗vue seo 优化方案
  • wordpress 连接flickrgoogleseo优化
  • 南宁高端网站建设公司推广方案怎么写
  • html手机网页制作成都官网seo服务
  • 做网站需要的参考文献如何创建一个自己的网站
  • 之梦网站怎么做seo千万别在百度上搜别人名字
  • 做网站的人是什么职位想做游戏推广怎么找游戏公司
  • 设计企业网站流程东莞网站排名提升
  • 想做外贸去哪个网站做2023年6月份疫情严重吗
  • 先做网站还是先解析seo的中文含义是
  • 用wix做网站需要备案吗营销手段和技巧
  • 大兴模版网站开发公司哪家好统计网站流量的网站
  • 中国做网站知名的公司100个裂变营销案例
  • css 建设网站 图文教程外包服务公司
  • java 网站开发工具南宁seo优化