微信小程序换肤功能实现方法详细步骤与探讨
1082
2022-10-05
codeforces 400 D Dima and Bacteria
Dima took up the biology of bacteria, as a result of his experiments, he invented k types of bacteria. Overall, there are n bacteria at his laboratory right now, and the number of bacteria of type i equals ci. For convenience, we will assume that all the bacteria are numbered from 1 to n. The bacteria of type ci are numbered from to .
With the help of special equipment Dima can move energy from some bacteria into some other one. Of course, the use of such equipment is not free. Dima knows m ways to move energy from some bacteria to another one. The way with number i can be described with integers ui, vi and xi mean that this way allows moving energy from bacteria with number ui to bacteria with number vi or vice versa for xi dollars.
Dima’s Chef (Inna) calls the type-distribution correct if there is a way (may be non-direct) to move energy from any bacteria of the particular type to any other bacteria of the same type (between any two bacteria of the same type) for zero cost.
As for correct type-distribution the cost of moving the energy depends only on the types of bacteria help Inna to determine is the type-distribution correct? If it is, print the matrix d with size k × k. Cell d[i][j] of this matrix must be equal to the minimal possible cost of energy-moving from bacteria with type i to bacteria with type j.
Input The first line contains three integers n, m, k (1 ≤ n ≤ 105; 0 ≤ m ≤ 105; 1 ≤ k ≤ 500). The next line contains k integers c1, c2, …, ck (1 ≤ ci ≤ n). Each of the next m lines contains three integers ui, vi, xi (1 ≤ ui, vi ≤ 105; 0 ≤ xi ≤ 104). It is guaranteed that .
Output If Dima’s type-distribution is correct, print string «Yes», and then k lines: in the i-th line print integers d[i][1], d[i][2], …, d[i][k] (d[i][i] = 0). If there is no way to move energy from bacteria i to bacteria j appropriate d[i][j] must equal to -1. If the type-distribution isn’t correct print «No».
Examples Input 4 4 2 1 3 2 3 0 3 4 0 2 4 1 2 1 2 Output Yes 0 2 2 0 Input 3 1 2 2 1 1 2 0 Output Yes 0 -1 -1 0 Input 3 2 2 2 1 1 2 0 2 3 1 Output Yes 0 1 1 0 Input 3 0 2 1 2 Output No
题意:给定一些细菌的群落 然后每个群落里都有细菌 求 同一个群落里的细菌能否 不花费代价到达
如果不行输出NO可以输出YES 然后还需要求 各个细菌群落之间的最短路
首先并查集 判断是否每个群落细菌都能不花费代价到达
然后缩点跑floyd即可
#include
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~