zoukankan      html  css  js  c++  java
  • 控制公司(dfs)

    题意

    有些公司是其他公司的部分拥有者,因为他们获得了其他公司发行的股票的一部分。例如,福特公司拥有马自达公司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。至多有100个公司。


    const
    maxn=100;
    var
    i,j,k,x,y,n:longint;
    b:array[0..maxn]of longint;
    a,c:array[0..maxn,0..maxn]of longint;
    f:array[0..maxn]of boolean;
    procedure init;
    var
    i:longint;
    begin
        readln(n);
        for i:=1 to n do
        begin
            readln(x,y,c[x,y]);
            inc(a[x,0]);
            a[x,a[x,0]]:=y;
        end;
        fillchar(f,sizeof(f),1)
    end;
    procedure dfs(k:longint);
    var
    i:longint;
    begin
        for i:= 1 to a[k,0] do
        inc(b[a[k,i]],c[k,a[k,i]]);
        for i:=1 to a[k,0] do
        begin
            if (b[a[k,i]]>50) and f[a[k,i]] then
            begin
                f[a[k,i]]:=false;
                dfs(a[k,i]);
                f[a[k,i]]:=true;
            end;
        end;
    end;
    procedure main;
    var
    i:longint;
    begin
        for i:=1 to 100 do
        begin
            fillchar(b,sizeof(b),0);
            f[i]:=false;
            dfs(i);
            f[i]:=true;
            for j:=1 to 100 do
            if (b[j]>50) and (i<>j) then writeln(i,' ',j);
        end;
    end;
    begin
        init;
        main;
    end.

  • 相关阅读:
    itextpd f生成 pdf 文件
    java word文档 转 html文件
    Activiti之 Exclusive Gateway
    activiti入门
    lucene分词器与搜索
    这款小程序 能让你和孙悟空一样 可以七十二变
    西游记中神兽谛听的能力 这款小程序也有
    想拥有一款钢铁侠Jarvis管家的软件吗?
    微信小程序开发填坑指南V1
    NaviSoft31.源码开发完成
  • 原文地址:https://www.cnblogs.com/YYC-0304/p/9500154.html
Copyright © 2011-2022 走看看