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

「一本通 3.3 练习 3」Easy SSSP

[{"sectionTitle":"题目描述","type":"Text","text":"原题来自:Vijos P1053\r\n\r\n输入数据给出一个有 NN 个节点,MM 条边的带权有向图。要求你写一个程序,判断这个有向图中是否存在负权回路。如果从一个点沿着某条路径出发,又回到了自己,而且所经过的边上的权和小于 00,就说这条路是一个负权回路。\r\n\r\n如果存在负权回路,只输出一行 1-1;如果不存在负权回路,再求出一个点 SS 到每个点的最短路的长度。约定:SSSS 的距离为 00,如果 SS 与这个点不连通,则输出 NoPath。","subType":"markdown"},{"sectionTitle":"输入格式","type":"Text","text":"第一行三个正整数,分别为点数 NN,边数 MM,源点 SS;\r\n\r\n以下 MM 行,每行三个整数 a,b,ca, b, c,表示点 a,ba, b 之间连有一条边,权值为 cc。","subType":"markdown"},{"sectionTitle":"输出格式","type":"Text","text":"如果存在负权环,只输出一行 1-1,否则按以下格式输出:\r\n\r\n共 NN 行,第 ii 行描述 SS 点到点 ii 的最短路:\r\n- 如果 SSii 不连通,输出 NoPath;\r\n- 如果 i=Si = S,输出 00。\r\n- 其他情况输出 SSii 的最短路的长度。","subType":"markdown"},{"sectionTitle":"样例","type":"Sample","text":"","subType":"markdown","payload":["6 8 1\n1 3 4\n1 2 6\n3 4 -7\n6 4 2\n2 4 5\n3 6 3\n4 5 1\n3 5 4","0\n6\n4\n-3\n-2\n7"]},{"sectionTitle":"数据范围与提示","type":"Text","text":"对于全部数据,$2\\le N\\le 1000,1\\le M\\le 10^5,1\\le a,b,S\\le N,|c|\\le 10^6$。","subType":"markdown"}]