#E. 「一本通 3.3 练习 3」Easy SSSP

    传统题 1000ms 256MiB

「一本通 3.3 练习 3」Easy SSSP

该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。

【题目描述】

原题来自:Vijos P1053

输入数据给出一个有 N 个节点,M 条边的带权有向图。要求你写一个程序,判断这个有向图中是否存在负权回路。如果从一个点沿着某条路径出发,又回到了自己,而且所经过的边上的权和小于 0,就说这条路是一个负权回路。

如果存在负权回路,只输出一行 −1;如果不存在负权回路,再求出一个点S到每个点的最短路的长度。约定:S 到 S 的距离为 0,如果 S 与这个点不连通,则输出 NoPath。

【输入】

第一行三个正整数,分别为点数 N,边数 M,源点 S;

以下 M 行,每行三个整数 a,b,c,表示点 a,b 之间连有一条边,权值为 c。

【输出】

如果存在负权环,只输出一行 −1,否则按以下格式输出:

共 N 行,第 i 行描述 S 点到点 i 的最短路:

如果 S 与 i 不连通,输出 NoPath;

如果 i=S,输出 0。

其他情况输出 S 到 i 的最短路的长度。

【输入样例】

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

【输出样例】

0
6
4
-3
-2
7

【提示】

数据范围:

对于全部数据,2≤N≤1000,1≤M≤105,1≤a,b,S≤N,∣c∣≤106。

做这道题时,你不必为超时担心,不必为不会算法担心,但是如此「简单」的题目,你究竟能 AC 么?

【来源】

一本通在线评测

CSP-J算法100班-最短路SPFA

未认领
状态
已结束
题目
6
开始时间
2023-4-21 0:00
截止时间
2023-4-29 23:59
可延期
24 小时