基于堆的基本操作的介绍

2016-02-19 09:41 6 1 收藏

今天图老师小编要向大家分享个基于堆的基本操作的介绍教程,过程简单易学,相信聪明的你一定能轻松get!

【 tulaoshi.com - 编程语言 】

  我们期望的数据结构能支持插入操作,并能方便地从中取出具有最小或最大关键码的记录,这样的数据结构即为优先级队列。在优先级队列的各种实现中,堆是最高效的一种数据结构。
  最小堆:任一结点的关键码均小于或等于它的左右子女的关键码,位于堆顶的结点的关键码是整个元素集合的最小的,所以称它为最小堆。最大堆类似定义。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  创建堆:采用从下向上逐步调整形成堆得方法来创建堆。为下面的分支结点调用下调算法siftDown,将以它们为根的子树调整为最小堆。从局部到整体,将最小堆逐步扩大,直到将整个树调整为最小堆。

  插入一个元素:最小堆的插入算法调用了另一种堆得调整方法siftUp,实现自下而上的上滑调整。因为每次新结点总是插在已经建成的最小堆后面,这时必须遵守与sift相反的比较路径,从下向上,与父结点的关键码进行比较,对调。

  删除一个元素:从最小堆删除具有最小关键码记录的操作时将最小堆的堆顶元素,即其完全二叉树的顺序表示的第0号元素删去,去把这个元素取走后,一般以堆得最后一个结点填补取走的堆顶元素,并将堆的实际元素个数减1.但是用最后一个元素取代堆顶元素将破坏堆,需要调用siftDown算法进行调整堆。

本文代码均以最小堆的实现为例。
代码如下:

#includeiostream
#includeassert.h
usingnamespace std;

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

constint maxheapsize=100;
staticint currentsize=0;

//从上到下调整堆
void siftDown(int* heap,int currentPos,int m)
{
    int i=currentPos;
    int j=currentPos*2+1;//i's leftChild
int temp=heap[i];
    while(j=m)
    {
        if(jm&&heap[j]heap[j+1]) j++;// j points to minChild
if(temp=heap[j]) break;
        else
        {
            heap[i]=heap[j];
            i=j;
            j=2*i+1;
        }
    }
    heap[i]=temp;
}

//从下向上调整堆
void siftUp(int* heap, int start)
{
    int i=start,j=(i-1)/2;
    int temp=heap[i];

    while(i0)
    {
        if(heap[j]temp)
        {
            heap[i]=heap[j];
            i=j;
            j=(i-1)/2;
        }
        elsebreak;
    }
    heap[i]=temp;
}

//构建堆
int* Heap(int*arr, int size)
{
    int i;
    currentsize=size;
    int* heap =newint[maxheapsize];
    assert(heap!=NULL);
    for(i=0;icurrentsize;i++) heap[i]=arr[i];
    int currentPos=(currentsize-2)/2;
    while(currentPos=0)
    {
        siftDown(heap,currentPos,currentsize-1);
        currentPos--;
    }
    return heap;
}

//增加一个元素
void insert(int* heap,int value)
{
    if(currentsize=maxheapsize)
    {
        cout"Heap is full!"endl;
        return ;
    }
    heap[currentsize]=value;
    siftUp(heap,currentsize);
    currentsize++;
}

//删除一个元素,并返回删除前的堆顶元素
int removemin(int* heap)
{
    assert(currentsize=0);
    int removeValue=heap[0];
    heap[0]=heap[currentsize-1];
    currentsize--;
    siftDown(heap,0,currentsize-1);
    return removeValue;
}

int main()
{
    constint size=10;
    int arr[size]={2,1,3,0,8,1,6,9,7,10};
    int* heap=Heap(arr,size);
    //堆排序
for(int i=0;isize;i++)
    {
        arr[i]=removemin(heap);
        coutarr[i]endl;
    }
    delete []heap;
    return0;

 
 

}

来源:https://www.tulaoshi.com/n/20160219/1591712.html

延伸阅读
标签: 游戏动漫
《失落的星球2》基本操作系统详细介绍 虽然游戏已经偷跑好几天了 不少人已经通关,但初次接触的人依然对游戏抱有很多疑问 而且这些问题相对集中 在这里就把游戏一些未说明的东西列出来 方便新接触的朋友和还不太了解本作的朋友更顺利的体验游戏的乐趣。 操作: 除了游戏按键设置界面的功能以外 游戏还有一些没有说明的组合键。以...
《生化奇兵2》基本操作与武器介绍 基本操作 鼠标左键---武器射击 鼠标右键---使用特殊能力 鼠标中键---更换弹药 鼠标滚轮---更换武器 W---前进 A---向左走 D---像右走 S---后退 C---蹲下 SPACE---跳跃 R---装填武器 左Ctrl---使用First AID kit(血包) F---使用/搜索/拿取 B---黑客 L---收听最近拿到的录音 J---回到身体中(使用...
标签:
在家就能吃到的美味,宝宝和妈妈一起享用的西式大餐!虾仁什锦焗的做法步骤 1. 准备食材。 2. 处理食材,玉米和豌豆分别焯水,去皮备用。 3. 洋葱、番茄、口蘑切碎备用。 ...
条件变量是线程之前同步的另一种机制。条件变量给多线程提供了一种会和的场所。当条件变量和互斥锁一起使用时,允许线程以无竞争的方式等待特定的条件发生。这样大大减少了锁竞争引起的线程调度和线程等待。      消息队列是服务器端开发过程中绕不开的一道坎,前面,我已经实现了一个基于互斥锁和三队列的消息队列,性能...
标签: Web开发
打包下载 一.本文干些啥: 通过javascript得到用户操作改变url参数从而实现某些功能,如查询(具体的查询由服务器端代码得到url中的参数组成查询语句实现)。 二.准备工作: 一个JQuery类库(我使用的版本为:1.3.2),一个工具类库(Tool.js,基本都是网上搜索来的代码),一个查询类库(Search.js,自己写的),一个htm页面(用来做练习),...

经验教程

953

收藏

40
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部