作者: 师照照 | 来源:发表于2020-06-14 21:52 被阅读0次

计算机数据结构中的堆,是什么?

堆是一种特殊的二叉树。二叉树是一棵树分叉的树,这棵树从根部开始分两条叉,每条叉又分出两条叉,每条叉的端点叫结点。树根是根结点。

堆是一种二叉树,它的结点排序是从上到下,同一行是从左到右,而且要求子结点必须大于父结点。所以最小值总是位于最上面。当结点有变化时,堆会自动调整来满足的以上规则。

当有结点插入时,首先会放入最后的一层的最右边。如果最后一层结点是满的,那么将它作为最后一层的最左结点的左子结点。然后与父结点比较,如果小于父结点,则与父结点交换位置,直至满足条件。自我调整结束。

那么,堆能用来做什么呢?它可以用来排序。将需要排序的数据构造成堆,处于最顶层的总是堆中最小的值。一次次将堆中根结点的值拿出顺序,即是这些数据从小到大的排序顺序。

相关文章

  • 堆 - 堆的应用

    堆有三个典型的应用场景:实现优先队列、求 Top K 、求中位数 实现优先队列 优先队列:队列的性质是先进先出,但...

  • 二叉堆是一棵满二叉树,父节点的值大于子节点。 用数组存储二叉堆,假如一个节点的下标为k,那么这个节点的左孩子就是2...

  • 应用: 排序,从小到大用最大堆,从大到小用最小堆 选出元素中的 top k 个top k 个最小数:数组前k个元素...

  • 完全二叉树 二叉堆 二叉堆有最大堆和最小堆的区别,最大堆只保证每个节点的父节点大于当前节点,但不保证上一层节点的值...

  • 堆的定义: n个元素序列{k1,k2,...,ki,...,kn},当且仅当满足下列关系时称之为堆: (ki...

  • http://bubkoo.com/2014/01/14/sort-algorithm/heap-sort/ 1 ...

  • 堆 …

    南山南,北山北,南山有谷堆,北山有花蕾,山坡下,大道中,野树停在石堆,秋风送,冷雪飘,旅途空旷叶儿飞,时间漫,皱纹...

  • 题目:100w个数中找出最大的100个。 维护一个100个元素的小根堆即可。 或者直接维护一个用来存储当前最大的1...

网友评论

      本文标题:

      本文链接:https://www.haomeiwen.com/subject/jiwfxktx.html