zoukankan      html  css  js  c++  java
  • 51nod 1366 贫富差距

    题目来源: TopCoder
    基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题
    一个国家有N个公民,标记为0,1,2,...,N-1,每个公民有一个存款额。已知每个公民有一些朋友,同时国家有一条规定朋友间的存款额之差不能大于d。也就是说,a和b是朋友的话,a有x元的存款,b有y元,那么|x-y|<=d。给定d值与N个人的朋友关系,求这个国家最富有的人和最贫穷的人的存款相差最大的可能值是多少?即求贫富差距的最大值的下界。若这个值为无穷大,输出-1.
    Input
    多组测试数据,第一行一个整数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].
    Output
    每组数据一行输出,即这个国家的贫富差距最大值的下界,如果这个值为无穷大输出-1.
    Input示例
    3
    3 10
    NYN
    YNY
    NYN
    2 1
    NN
    NN
    6 1000
    NNYNNN
    NNYNNN
    YYNYNN
    NNYNYY
    NNNYNN
    NNNYNN
    Output示例
    20
    -1
    3000



     默认他自己没有钱(好残忍)。。他的朋友有d,他朋友的朋友有d+d....

     然后 Floyd 求差距最大的两个人就可以了

     屠龙宝刀点击就送

     
    #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
    ",ans);
        }
        return 0;
    }
  • 相关阅读:
    网络基础知识
    mysql安装
    docker打包镜像
    python的基础
    python静态属性的理解
    python中的静态方法和类方法
    python类的两种创建方式
    python的继承
    python中time和datetime模块
    python之模块
  • 原文地址:https://www.cnblogs.com/ruojisun/p/7718750.html
Copyright © 2011-2022 走看看