控制公司(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.

原文地址:https://www.cnblogs.com/YYC-0304/p/9500154.html