#P4237. 荒芜的海洋

荒芜的海洋

题目背景

在一个渺远的海洋中,一场世纪大战级别的游戏上演了。

感谢 lsq 本人参与验题

题目描述

这块海洋上有n个小岛,小岛有m座石桥相连。有一些小岛上有wzt埋下的奖赏,它们非常诱人。它们的诱惑力用整数ki描述。而一些小岛上有lsq的雇佣兵,他们有一个价格,用整数bi描述。lsq必须花钱,他的雇佣兵才会帮他寻找奖赏。

雇佣兵的价格并不会变。对于每一个雇佣兵,在寻找过程中,他会越过一座座的桥,这过程中,他的价格会 加上他所经过的所有桥的长度

遗憾的是,不只有桥的阻挡,每座岛上有许多猛兽,虽然雇佣兵们都英勇无比,但驱逐猛兽的过程会让人很不爽。因此,对于每一个雇佣兵,价格会 加上他所经过的所有岛(包括出发岛)上的猛兽数量之和

lsq了解这里的一切情况,他需要做出决策,即决定他的每个雇佣兵应该去找哪个奖赏。lsq的目的是找到所有奖赏,并取得最大收益。每个雇佣兵只能雇佣一次。

收益的定义为: 所有奖赏的诱惑力减去lsq花的所有的钱

lsq的决策异常艰难,于是只好请 AK过NOI 的你来帮忙。

输入格式

第一行4个数,n(小岛总数),m(桥总数),a(lsq的雇佣兵总人数),b(奖赏总数)

接下来一行n个数,表示每个小岛上的猛兽数量

接下来m行,每行三个数u,v,w,表示u号小岛与v号小岛之间有一座长度为w的桥相连

接下来a行,每行两个数qi,pi,表示i号雇佣兵价格为qi,初始位置为pi号小岛

接下来b行,每行两个数ki,qi,表示i号奖赏的诱惑力为ki,位置为qi号小岛

输出格式

如果能找到所有奖赏,输出“Yes”,并在下一行输出能达到的最大满意度。

如果不能找到所有奖赏,输出“No”,并在下一行输出最多能找到多少奖赏。

4 6 3 2
16 37 22 24 
1 4 25
1 1 23
4 1 20
3 1 47
1 1 18
3 3 24
213 1
174 2
62 4
1493 3
2632 4
Yes
3741
4 2 3 2
16 37 22 24
1 4 25
1 3 12
213 1
174 3
62 4
1493 2
2632 4
No
1

提示

对于30% 的数据,满足n<=200,m<=200,b<=a<=30

对于50% 的数据,满足n<=500,m<=800,b<=a<=100

对于100% 的数据,满足n<=1000,m<=15000,b<=a<=300,其余数据保证不会爆int(Pascal语言为longint)

By Ebola