——在大佬的帮助下过了这道题
思路:
LYC大佬的博客里已经讲得很清晰了,我只是提一下要点。
求次短路,主要考虑两个方面:
①在不重复走一条路的前提下,把最短路的其中一段替换为另一段。
②找出最短路中的最短的一条边,重复走两次。(走过来又走回去)
分别求出这两方面所能算出的次短路的值,取小的那一条就是答案。
补充:
①读入的边要开结构体存起来,后面枚举求次短路要使用。
②所谓枚举,就是找出从开始一条一条的读出边的两端点、权值。确定其是否在最短路上(即它的 左端点到源点的最短路+右端点到源点的最短路+自身的边权 是否等于最短路长度。(注意细节:要判断这条边的两端点到源点的最短路是否有重合部分,如下图。)
设d[ a ]为 a 到源点的最短路,d[ b ]为 b 到源点的最短路,很显然,两条最短路有重合的地方,就需要将 a 点与 b 点交换位置,使得两条最短路没有重合,才能将 a->b 的权值加入。
代码实现:
if(d1[x]+d2[y]>d1[y]+d2[x]) swap(x,y);
效果如下:
完整代码:
#include #include #include #include #include #include #include #include #include #include #include #include
其实两遍的Dijkstra函数可以简化为一遍,多打一遍练练模板。