ZOJ 1456 Minimum Transport Cost (dijkstra+dfs)

如果只求最短路径,那么这个题水的不能再水了,但关键是他还要输出字典序最短的最短路径,这不知难倒了多少人。

 

刚开始的时候,我想要把说有的最短路径都找出来,但是找不到合适的方法,未果。

 

之后某媛提示可以用dfs去找所有路径,,,恍悟~dfs在找路径的时候每次都是从最字典序小的那个开始,所以当你找到一条符合题意的最短路径的时候,它一定就是我们需要的路径。其中只需要一个数组去储存路径信息。当第一次搜索到合适的时候就输出。

 

需要注意的地方:

1、输出时候有无数个空格,要注意是否一致。我因此WA了一次。

2、每个城市 i 通过也需要费用,把这个费用加到pathcost[i][j]上,也就是使他成为权值的一部分。dfs开始之前把总费用初始为初始城市通过费用的负值。

 

需要测试数据的留下邮箱~

 

评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值