数据结构——堆

1、概念与结构

  • 一般堆使用顺序结构的数组来储存数据,堆是一种特殊的二叉树,具有二叉树的特性的同时,还具备的特性

2、堆的性质

  • 堆中的某个结点的值总是不大于不小于其父节点的值
  • 堆总是一棵完全二叉树
  • 对于具有 n 个结点的完全⼆叉树,如果按照从上⾄下从左⾄右的数组顺序对所有结点从 0 开始编号,则对于序号为 i 的结点有:

1、若 i>0 , i 位置结点的双亲序号: (i-1)/2 ; i=0 , i 为根结点编号,⽆双亲结点

2、若 2i+1,左孩⼦序号: 2i+1 , 2i+1>=n 否则⽆左孩⼦

3、 若 2i+2,右孩⼦序号: 2i+2 , 2i+2>=n 否则⽆右孩⼦

3、堆的结构演示

4、堆的实现

(1)堆的初始化

(2)堆的销毁

(3)堆的向上调整算法

  • 小堆:使用<
  • 大堆:使用>

(4)堆的打印

(5)入堆

  • 首先要判断空间是否足够,即判断size和capacity的值是否相等
  • 将堆内的arr[php->size]位置赋值为x,并且进行向上调整排序

(6)堆的判空

(7)出堆

  • 首先要判断堆是否为空
  • 出堆操作只能对堆顶操作
  • 最后进行出堆操作

(8)向下调整算法

(9)取堆顶数据

(10)堆排序

此处已经在下面文章中的详细讲解,各位可以跳转阅读

数据结构---排序-CSDN博客

(11)Top-k问题

相关推荐
爱学习的小仙女!3 小时前
算法效率的度量 时间复杂度 空间复杂度
数据结构·算法
AndrewHZ3 小时前
【复杂网络分析】什么是图神经网络?
人工智能·深度学习·神经网络·算法·图神经网络·复杂网络
Swizard3 小时前
拒绝“狗熊掰棒子”!用 EWC (Elastic Weight Consolidation) 彻底终结 AI 的灾难性遗忘
python·算法·ai·训练
Trouvaille ~3 小时前
【C++篇】把混沌映射成秩序:哈希表的底层哲学与实现之道
数据结构·c++·stl·哈希算法·散列表·面向对象·基础入门
Yeats_Liao4 小时前
MindSpore开发之路(四):核心数据结构Tensor
数据结构·人工智能·机器学习
fab 在逃TDPIE4 小时前
Sentaurus TCAD 仿真教程(十)
算法
天赐学c语言4 小时前
12.19 - 买卖股票的最佳时机 && const的作用
c++·算法·leecode
菜鸟233号4 小时前
力扣78 子集 java实现
java·数据结构·算法·leetcode
yesyesyoucan4 小时前
在线魔方解谜站:从零入门到精通的智能魔方学习平台
学习·算法
Han.miracle4 小时前
数据结构与算法--008四数之和 与经典子数组 / 子串问题解析
数据结构·算法