PriorityQueue+Dijkstra优先队列优化的Dijkstra

本文介绍了PriorityQueue+Dijkstra算法,作为优化Dijkstra的一种方法,它比原生Dijkstra效率更高,虽略低于堆优化,但实现简单且不易出错。通过使用Java的PriorityQueue,可以方便地实现优先队列优化的Dijkstra,适用于处理大规模数据。文中以蓝桥杯最短路问题为例,展示了算法的实现,并进行了性能测试,平均执行时间为320ms,相较于原生Dijkstra有显著提升。
摘要由CSDN通过智能技术生成

前面分别介绍了“原生的Dijkstra”即毫无优化的Dijkstra,但这种Dijkstra的效率较低为n^n,因此面对较大数据量的时候需要对其进行优化,也就是优化所采用的贪心策略的实现,因此就有了Heao+Dijkstra堆优化的Dijkstra,但是堆优化的实现很复杂,而PriorityQueue+Dijkstra优先队列优化的Dijstra的效率虽然略低于堆优化的Dijkstra,但是实现却容易的多,也不容易出错,因为可以借助java类库中的PriorityQueue来实现,因此优先队列优化的Dijkstra是首选,其实java类库PriorityQueue的底层实现原理就是推排序微笑


还以蓝桥杯“最短路”为例实现PriorityQueue+Dijkstra:

 算法训练 最短路  
时间限制:1.0s   内存限制:256.0MB
      
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值