求经过路径最少的最短路

题目保证最短路不止一条,求经过路径最少的最短路.
分析:假设数据小的话能够用floyed+Dp求出。在保证最短路的情况下更新路径少的情况就可以,dis表示最短路,大盘dp[i,j]表示从i到j的最短路所需最少路径条数;但一旦数据大于300,非常有超时危急,以下是一个小技巧:将边权乘以10^8后+1(注意乘以几要视数据大小而定),再用高效的spfa或堆优化的dijkstra来跑。


为什么呢?举个样例:假定边数不超过100000(10的5次方),而边权*10^8后能够说远大于它,那么在更新最短路时+1会算入距离,就能够将其视为路径数,随最短路更新而自己主动更新。


最后跑完后取出走后几位数就可以。即为经过路径最少的最短路的经过路径数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值