题目大意:有N头牛,M部电影,如果两头牛参与了同一部电影,那么他们的相互度就为1,否则他们的相互度就需要由其他牛来决定,例如有四头牛,A和B共同参演第1部,B和C共同参演第2部,C和D共同参演第3部,那么A和C的相互度就为1+1=2,A和D的相互度就是1+1+1= 3。求一头牛和其他所有的相互度和最小,输出最小值*100/(n-1)。
分析:很容易想到Floyd算法,水之。
代码:
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int main() {
int n, m;
while(scanf("%d%d", &n, &m) != EOF) {
int d[400][400];
for(int i = 1; i <= n; i++) {
d[i][i] = 0;
for(int j = i+1; j <= n; j++)
d[i][j] = d[j][i] = 1 << 29;
}
for(int p = 0; p < m; p++) {
int k;
scanf("%d", &k);
int a[400];
for(int i = 0; i < k; i++) {
scanf("%d", &a[i]);
for(int j = 0; j < i; j++)
d[a[i]][a[j]] = d[a[j]][a[i]] = 1;
}
}
for(int k = 1; k <= n; k++)
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
d[i][j] = min(d[i][j], d[i][k]+d[k][j]);
int ans = 1 << 29;
for(int i = 1; i <= n; i++) {
int dist = 0;
for(int j = 1; j <= n; j++)
if(i != j)
dist += d[i][j];
ans = min(ans, dist);
}
printf("%d\n", ans*100/(n-1));
}
return 0;
}