索引优先队列

索引优先队列是一种改进的优先队列,解决了不能直接访问和更新已存在对象的问题。通过关联整数和对象,能快速索引并更新对象值。在Dijkstra算法中,索引优先队列用于保存顶点与其最短路径长度,便于查找和更新。算法通过维护堆有序的pq数组和逆序qp数组实现,插入和更新操作更便捷,时间复杂度为O(ElogV)。
摘要由CSDN通过智能技术生成

一、算法思想

  优先队列的原理本质上就是利用完全二叉树的结构实现以log2n的时间复杂度删除队列中的最小对象(这里以小堆顶为例)。完全二叉树又可以通过数组下标实现索引,当插入一个对象的时候,利用上浮操作更新最小对象。当删除堆顶最小对象时,将末尾的对象放置到堆顶上,然后执行下沉操作。

  优先队列有一个缺点,就是不能直接访问已存在于优先队列中的对象,并更新它们。这个问题在Dijistra算法中就有明显的体现,有时候我们需要更新已在队列中的顶点的距离。为此就需要设计一种新型的数据结构来解决这个问题,这就是本文要介绍的索引优先队列。

  索引优先队用一个整数和对象进行关联,当我们需要跟新该对象的值时,可以通这个整数进行快速索引,然后对对象的值进行更新。当然更新后的对象在优先队列中的位置可能发生变化,这样以保证整个队列还是一个优先队列。

二、算法流程

1,增加数组keys用来保存优先队列元素(item or key)

2,pq数组则改用于保存索引(pq[i] = k,k为索引),这里的pq数组仍然保持堆有序,即pq[1]所对应的元素(keys[pq[1]])大于或等于pq[2]、pq[3]所对应的元素(keys[pq[2]]、keys[pq[3]])。

3,增加数组qp,用于保存pq的逆序。如果pq[i] = k,则qp[k] = i,也就是pq[qp[k]] = k。如果k不在队列之中,则qp[k] = -1。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值