【UOJ 639】控制公司

#639. 控制公司

Statistics

【题目描述】:

有些公司是其他公司的部分拥有者,因为他们获得了其他公司发行的股票的一部分。例如,福特公司拥有马自达公司12%的股票。据说,如果至少满足了以下条件之一,公司A就可以控制公司B了:

  • 公司A = 公司B。

  • 公司A拥有大于50%的公司B的股票。

  • 公司A控制K(K >= 1)个公司,记为C1, ..., CK,每个公司Ci拥有xi%的公司B的股票,并且x1+ .... + xK > 50%。

你将被给予一系列的三对数(i,j,p),表明公司i拥有公司j的p%的股票。计算所有的数对(h,s),表明公司h控制公司s。

写一个程序读入三对数(i,j,p),并且找出所有的数对(h,s),使得公司h控制公司s。

【输入描述】:

第一行: N,表明接下来三对数的数量。

第二行到第N+1行:每行三个整数作为一个三对数(i,j,p),如上文所述。

【输出描述】:

输出零个或更多个的控制其他公司的公司。每行包括两个整数表明序号为第一个整数的公司控制了序号为第二个整数的公司。将输出的每行以第一个数字升序排列(并且第二个数字也升序排列来避免并列)。请不要输出控制自己的公司。

【样例输入】:

3
1 2 80
2 3 80
3 1 20

【样例输出】:

1 2
1 3
2 3

【时间限制、数据范围及描述】:

时间<=1s,空间<=128M

对于30%的数据i,j<=10

对于全部的数据i,j<=100

对于全部的数据N,p<=100

题解:普通暴力呃呃

#include<cstdio>
#include<iostream>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
const int N=102;
int f[N][N],vis[N][N];
int n,x,y,z;
int main(){
    freopen("639.in","r",stdin);
    freopen("639.out","w",stdout);
    scanf("%d",&n);
    for(int i=1;i<=n;i++){
        scanf("%d %d %d",&x,&y,&z);
        f[x][y]=z;
    }
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
            if(f[i][j]>50) vis[i][j]=1;
            //if(i==j) continue;
            //if(vis[i][j]==1) printf("%d %d
",i,j);
        }
    }
    
//    for(int ii=1;ii<=200;ii++){
        
    
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
            if(i==j) continue; 
            int sum=0;
            for(int k=1;k<=n;k++){
                if(k==i || k==j) continue;
                if(vis[i][k])sum+=f[k][j];
            }
            if(sum>50){
                vis[i][j]=1;
                //printf("%d %d
",i,j);
                continue;
            }
        }
    }//}
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
            if(i==j) continue;
            if(vis[i][j]==1) printf("%d %d
",i,j);
        }
    }
    return 0;
}
原文地址:https://www.cnblogs.com/wuhu-JJJ/p/14076181.html