#sPFAybttg030305. 1508:Easy SSSP
1508:Easy SSSP
1508:Easy SSSP
题目描述
输入数据给出一个有 个节点, 条边的带权有向图。要求你写一个程序,判断这个有向图中是否存在负权回路。如果从一个点沿着某条路径出发,又回到了自己,而且所经过的边上的权和小于 0,就说这条路是一个负权回路。
如果存在负权回路,只输出一行 -1;如果不存在负权回路,再求出一个点 到每个点的最短路的长度。约定: 到 的距离为 ,如果 与这个点不连通,则输出 NoPath。
输入格式
第一行三个正整数,分别为点数 ,边数 ,源点 ;
以下 行,每行三个整数 ,表示点 到点 之间连有一条有向边,权值为 。
输出格式
如果存在负权环,只输出一行 -1,否则按以下格式输出:
共 行,第 行描述 点到点 的最短路:
- 如果 与 不连通,输出
NoPath; - 如果 ,输出 ;
- 其他情况输出 到 的最短路的长度。
样例
样例输入 #1
6 8 1
1 3 4
1 2 6
3 4 -7
6 4 2
2 4 5
3 6 3
4 5 1
3 5 4
样例输出 #1
0
6
4
-3
-2
7
样例解释 #1
- 图中没有负权环。
- 从源点 出发:
- 到 :
- 到 :,长度
- 到 :,长度
- 到 :,长度
- 到 :,长度
- 到 :,长度
数据范围
对于全部数据:
时空限制
- 时间限制:1000 ms
- 内存限制:65536 KB
注意:本题需要先判断整个图中是否存在负权环(可以用 Bellman-Ford 或 SPFA 判断),如果没有负权环,再计算从源点 到所有点的最短路径(注意处理不连通的情况)。由于 ,,需要选择高效的算法。