登录
首页 >  文章 >  java教程

优先级队列

来源:dev.to

时间:2024-07-20 08:19:44 484浏览 收藏

文章不知道大家是否熟悉?今天我将给大家介绍《优先级队列》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

优先级队列可以使用堆来实现。普通队列是先进先出的数据结构。元素被追加到队列的末尾并从开头删除。在优先级队列中,元素被分配优先级。访问元素时,首先删除优先级最高的元素。例如,医院的急诊室为患者分配优先号码;优先级最高的患者首先得到治疗。

优先级队列可以使用堆来实现,其中根是队列中优先级最高的对象。堆是在堆排序中引入的。优先级队列的类图如下图所示。它的实现在下面的代码中给出。

Image description

优先级队列

下面的代码给出了为患者使用优先级队列的示例。 Patient 类在第 21-38 行中定义。在第 6-9 行中创建了四个具有相关优先级值的患者。第 8 行创建一个优先级队列。患者排在第 12-15 行。 18 号线将一名患者从队列中移出。

Image description

辛迪(优先级:7)蒂姆(优先级:5)约翰(优先级:2)吉姆(优先级:1)

终于介绍完啦!小伙伴们,这篇关于《优先级队列》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>