首页 > 其他 > 详细

优先队列(堆)浅谈

时间:2014-03-30 12:46:30      阅读:517      评论:0      收藏:0      [点我收藏+]

1、概述

在分析堆之前,你可以理解一下队列和栈,其实他们都是对任务的一种调度策略,只是各自的准则不同罢了,队列为先进先出,栈为先进后出,而堆是每个任务分配了一个优先权,根据优先权进行任务的执行。调度程序通过堆始终能获取优先权最高的任务进行执行。比较常见应用为操作系统。

2、模型

堆又称为优先队列,其通常包括至少两种操作:insert(入队操作)和deleteMin(出队操作)。

3、实现方式

a.链表实现

简单链表的实现过程为在链表的头insert元素,使用O(1)时间完成,每次deleteMin元素,查找出链表中最小的元素,花费O(N)时间完成;另外一种方法是让链表保持有序状态,在进行任务insert的时候进行排序(花费O(N)),每次获取链表的头(花费O(1))。

b.二叉查找树实现

使用二叉查找树实现中,对于insert和deleteMin花费时间均为O(log(N)),但存在一个潜在问题,既是容易造成不平衡二叉树,因为deleteMin始终是从左边开始往右边进行删除。

c.二叉堆实现

二叉堆对于优先队列实现比较普遍,通二叉查找树一样,二叉堆具有两个性质:结构性和堆序性。
结构性:必须是一颗完全二叉树,树的插入从左到右,一颗完全二叉树的高度为小于log(N)的最大整数。
堆序性:二叉树的父节点必须小于两个子节点。
在二叉堆的具体实现中,通过一个数组来存储所有的元素,具体操作包括:
insert操作:在数组的最后位置添加该元素,然后再通过二叉堆的性质上虑新插入的元素,直到找到该元素的合适位置;
deleteMin操作:删除的元素为根元素,同时把数组最后元素赋值给根元素,根元素根据二叉堆的性质下虑,直到找到合适的位置。
buildHeap操作:对一组输入的数据进行构造堆,通过从下到上对非叶子节点进行下虑,所花费时间为O(N)

优先队列(堆)浅谈,布布扣,bubuko.com

优先队列(堆)浅谈

原文:http://blog.csdn.net/eddle/article/details/22574365

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!