求从点i到点j,再从点j到点i的最短路程,其中每条无向边只能走一次
如果考虑无向环会很复杂,根据分类,这道题用费用流做,把边上距离看成是费用,然后考虑怎么构图
从点j走到点i的边,反向之后就是从i走到j了,于是等于从i到j走两次,这样,建立一个源点,到起点的容量为2,费用为0,表示从起点走两次,建立一个汇点,点N到汇点的容量为2,费用为0,表示到达N点两次,每天边上的容量为1,表示只能走一次,这样就把整个题目意思表示出来了
注意可能有重边,用邻接表储存边
这道题简单地求两次最短路径是不行的,由于一条边只能走一次的限制,分别求两次的最短距离加起来不一定是最短的
代码: