美文网首页
11.Hedp(堆)

11.Hedp(堆)

作者: a_tomcat | 来源:发表于2017-12-18 16:22 被阅读0次

概念:

堆(Heap)亦被称为:优先队列(priority queue)
Binary Heap is a common type of Heap.
性质:堆的实现通过构造二叉堆(binary heap),这种数据结构具有以下性质
1.任意节点小于等于它的所有后裔,最小元素在堆的根上(堆序性)。
2.堆总是一棵完全树。complete tree,在node数量相同的情况下,完全树高度最小height肯定是lgn,traversal或其他操作复杂度更低,普通的二叉树则没有这种优势。
3.将根节点最大的堆叫做MAX HEAP, 根节点最小的堆叫做最小堆MIN HEAP
4.index of IChild = index of parent * 2+1
5.index of rChild = index of parent * 2+2
(第4第5的特性决定了二叉堆可以将所有的node放到一个数组中可以快速地找到某个node的子node)
6.unsorted but follow rules above

java PriorityQueue支持的基本操作

        Queue<Integer> pq = new PriorityQueue<>();
        pq.offer(6);
        pq.offer(5);
        pq.offer(4);//复杂度O(lgn) 插入到heap的最后一个index,再跟parent节点比较,比parent小就往上冒泡

        System.out.println(pq.peek());//4 O(1)
        System.out.println(pq.poll());//4
        System.out.println(pq.poll());//5
        //pq.poll() 复杂度O(lgn) 删除第一个index,再将最后一个元素移到顶部,再往下压与较小的子节点交换,直到没有比它小的节点

练习

`1.find smallest k elements from an unsorted array of size n
solution1: maintain a MAX-Heap of size k

相关文章

  • 11.Hedp(堆)

    概念: 堆(Heap)亦被称为:优先队列(priority queue)Binary Heap is a comm...

  • 堆 - 堆的应用

    堆有三个典型的应用场景:实现优先队列、求 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 ...

  • 堆 …

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

网友评论

      本文标题:11.Hedp(堆)

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