#T1503. 「一本通 3.2 练习 7」道路和航线

「一本通 3.2 练习 7」道路和航线

题目描述

原题来自:USACO 2011 Jan. Gold

Farmer John 正在一个新的销售区域对他的牛奶销售方案进行调查。他想把牛奶送到 TT 个城镇 ,编号为 11TT。这些城镇之间通过 RR 条道路(编号为 11RR)和 PP 条航线(编号为 11PP)连接。每条道路 ii 或者航线 ii 连接城镇 A_iA\_iB_iB\_i,花费为 C_iC\_i​​ 。

对于道路,0leC_ile1040 \\le C\_i \\le 10^4​​ ,然而航线的花费很神奇,花费 C_iC\_i 可能是负数。道路是双向的,可以从 A_iA\_iB_iB\_i​​ ,也可以从 B_iB\_iA_iA\_i​​ ,花费都是 C_iC\_i​​ 。然而航线与之不同,只可以从 A_iA\_iB_iB\_i​​ 。

事实上,由于最近恐怖主义太嚣张,为了社会和谐,出台了一些政策保证:如果有一条航线可以从 A_iA\_iB_iB\_i​​ ,那么保证不可能通过一些道路和航线从 B_iB\_i 回到 A_iA\_i​​ 。由于 FJ 的奶牛世界公认十分给力,他需要运送奶牛到每一个城镇。他想找到从发送中心城镇 SS 把奶牛送到每个城镇的最便宜的方案,或者知道这是不可能的。

输入

第一行为四个空格隔开的整数:T,R,P,ST,R,P,S

第二到第 R+1R+1 行:三个空格隔开的整数(表示一条道路):A_i,B_iA\_i, B\_iC_iC\_i

R+2R+2R+P+1R+P+1 行:三个空格隔开的整数(表示一条航线):A_i,B_iA\_i, B\_i​​ 和 C_iC\_i​​ 。

输出

输出 TT 行,第 ii 行表示到达城镇 ii 的最小花费,如果不存在输出 NO PATH。

样例

6 3 3 4 
1 2 5 
3 4 5 
5 6 10 
3 5 -100 
4 6 -100 
1 3 -10
NO PATH 
NO PATH 
5 
0 
-95 
-100

提示

样例说明

一共六个城镇。在 112233445566 之间有道路,花费分别是 55,55,1010。同时有三条航线:353→5464→6131→3,花费分别是 −100100,−100100,−1010。FJ 的中心城镇在城镇 44。FJ 的奶牛从 44 号城镇开始,可以通过道路到达 33 号城镇。然后他们会通过航线达到 5566 号城镇。但是不可能到达 1122 号城镇。

数据范围:

对于全部数据,1T2.5×104,1R,P5×104,1A_i,B_i,ST1≤T≤2.5×10^4,1≤R,P≤5×10^4,1≤A\_i,B\_i,S≤T。保证对于所有道路,0C_i1040≤C\_i≤10^4,对于所有航线,104C_i104−10^4≤C\_i≤10^4​​ 。

来源

一本通在线评测