POJ2139--Six Degrees of Cowvin Bacon

题目大意:有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;
}


你可能感兴趣的:(POJ2139--Six Degrees of Cowvin Bacon)