如果只求最短路径,那么这个题水的不能再水了,但关键是他还要输出字典序最短的最短路径,这不知难倒了多少人。
刚开始的时候,我想要把说有的最短路径都找出来,但是找不到合适的方法,未果。
之后某媛提示可以用dfs去找所有路径,,,恍悟~dfs在找路径的时候每次都是从最字典序小的那个开始,所以当你找到一条符合题意的最短路径的时候,它一定就是我们需要的路径。其中只需要一个数组去储存路径信息。当第一次搜索到合适的时候就输出。
需要注意的地方:
1、输出时候有无数个空格,要注意是否一致。我因此WA了一次。
2、每个城市 i 通过也需要费用,把这个费用加到pathcost[i][j]上,也就是使他成为权值的一部分。dfs开始之前把总费用初始为初始城市通过费用的负值。
需要测试数据的留下邮箱~