标签:空间 panel tps floyd ring scan 一个 bsp 最大值
多组测试数据,第一行一个整数T,表示测试数据数量,1<=T<=5 每组测试数据有相同的结构构成。 每组数据的第一行两个整数N,d,表示人数与朋友间存款差的最大值,其中2<=N<=50,0<=d<=1000. 接下来有一个N*N的数组A,若A[i][j]=‘Y‘表示i与j两个人是朋友,否则A[i][j]=‘N‘表示不是朋友。其中A[i][i]=‘N‘,且保证 A[i][j]=A[j][i].
每组数据一行输出,即这个国家的贫富差距最大值的下界,如果这个值为无穷大输出-1.
3 3 10 NYN YNY NYN 2 1 NN NN 6 1000 NNYNNN NNYNNN YYNYNN NNYNYY NNNYNN NNNYNN
20 -1 3000
#include <iostream> #include <cstring> #include <cstdio> #define N 55 using namespace std; int T,n,d,ans=0,f[N][N]; char ch; inline int max(int a,int b) {return a>b?a:b;} int main(int argc,char *argv[]) { scanf("%d",&T); for(int n,d;T--;) { ans=0; scanf("%d%d",&n,&d); for(int i=1;i<=n;++i) for(int j=1;j<=n;++j) f[i][j]=(i!=j)*0x3f3f3f3f; for(int i=1;i<=n;++i) for(int j=1;j<=n;++j) { cin>>ch; if(ch==‘Y‘) f[i][j]=d; } for(int k=1;k<=n;++k) for(int i=1;i<=n;++i) for(int j=1;j<=n;++j) f[i][j]=min(f[i][j],f[i][k]+f[k][j]); bool flag=true; for(int i=1;i<=n;++i) for(int j=i+1;j<=n;++j) { if(f[i][j]==0x3f3f3f3f) flag=false; else ans=max(ans,f[i][j]); } !flag?puts("-1"):printf("%d\n",ans); } return 0; }
标签:空间 panel tps floyd ring scan 一个 bsp 最大值
原文地址:http://www.cnblogs.com/ruojisun/p/7718750.html