作者: 我好菜啊_ | 来源:发表于2019-11-24 17:51 被阅读0次

优先队列:取出元素的顺序是依照元素的优先权大小,而不是元素进入队列的先后顺序。
二叉堆
结构性:由数组表示的完全二叉树
有序性:任一结点的关键字是其子树所有结点的最大值(最小值)
最大堆/大顶堆 MaxHeap(MinHeap)
操作集

MaxHeap Create(int MaxSize);
Boolean IsFull(MaxHeap H);
Insert(MaxHeap H, ElementType item);
Boolean IsEmpty(MaxHeap H);
ElementType DeleteMax(MaxHeap H);
typedef struct HeapStruct *MaxHeap;
struct HeapStruct{
    ElementType *Elements;
    int Size;    int Capacity;
}

MaxHeap Create(int MaxSize)
{
    MaxHeap H=malloc(sizeof(struct HeapStruct));
    H->Elements=malloc((MaxSize+1)*sizeof(ElementType));
    //MaxSize+1是因为是从下标1位置开始放元素的
    H->Size=0;    H->Capacity=MaxSize;
    H->Elements[0]=MaxData;
    //哨兵,大于堆中所有可能的元素,便于后序操作
    return H;
}

//新元素在堆中上滤找到正确位置
void Insert(MaxHeap H, ElementType item)
{
    int i;
    if(IsFull(H)) {...}
    i=++(H->Size);
    for( ;H->Elements[i/2]<item;i/=2)    
        H->Elements[i]=H->Elements[i/2];
        //和父节点比较若比父节点大,则父节点下来,新结点上去
    H->Elements[i]=item;
}
//因为有个哨兵元素,即使插入的是最大的元素最终一定也能跳出循环

//删掉最大的元素
ElementType DeleteMax(MaxHeap H)
{
    int Parent, Child;
    ElementType MaxItem, temp;
    if(IsEmpty)...
    MaxItem=H->Elements[1];
    temp=H->Elements[H->Size];    H->Size--;
    for(Parent=1;Parent*2<=H->Size;Parent=Child){
        Child=Parents*2;
        if((Child!=H->Size)&&(H->Elements[Child]<H->Elements[Child+1))
            Child++; 
        if(temp>=H->Elements[Child]) break;
        else
            H->Elements[Parents]=H->Elements[Child];
    }
    H->Elements[Parent]=temp;
    return MaxItem;
堆.PNG
堆构建.PNG

相关文章

  • 堆 - 堆的应用

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