青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

POJ 1236 Network of Schools 強連通分量+縮點

 

Description

A number of schools are connected to a computer network. Agreements have been developed among those schools: each school maintains a list of schools to which it distributes software (the “receiving schools”). Note that if B is in the distribution list of school A, then A does not necessarily appear in the list of school B
You are to write a program that computes the minimal number of schools that must receive a copy of the new software in order for the software to reach all schools in the network according to the agreement (Subtask A). As a further task, we want to ensure that by sending the copy of new software to an arbitrary school, this software will reach all schools in the network. To achieve this goal we may have to extend the lists of receivers by new members. Compute the minimal number of extensions that have to be made so that whatever school we send the new software to, it will reach all other schools (Subtask B). One extension means introducing one new member into the list of receivers of one school.

Input

The first line contains an integer N: the number of schools in the network (2 <= N <= 100). The schools are identified by the first N positive integers. Each of the next N lines describes a list of receivers. The line i+1 contains the identifiers of the receivers of school i. Each list ends with a 0. An empty list contains a 0 alone in the line.

Output

Your program should write two lines to the standard output. The first line should contain one positive integer: the solution of subtask A. The second line should contain the solution of subtask B.

Sample Input

5
2 4 3 0
4 5 0
0
0
1 0

Sample Output

1
2

Source

   

題目大意:N(2<N<100)各學校之間有單向的網絡,每個學校得到一套軟件后,可以通過單向網絡向周邊的學校傳輸,問題1:初始至少需要向多少個學校發放軟件,使得網絡內所有的學校最終都能得到軟件。2,至少需要添加幾條傳輸線路(邊),使任意向一個學校發放軟件后,經過若干次傳送,網絡內所有的學校最終都能得到軟件。

具體算法:先用Korasaju Algorithm求出有向圖所有的強連通分量,然后將所有的強連通分量縮成一個點(縮點),這樣原來的有向圖就縮成了一個DAG圖(有向無環圖);用2個數組分別記錄新生成的DAG圖中的每個頂點(包括原來的頂點和強連通分量的縮點)是否有出邊和入邊,最后遍歷每個頂點,如果沒有入邊,則ans1++;如果沒有出邊,ans2++。最后所求即為ans1和max(ans1,ans2)。
#include <iostream>
#include 
<vector>
using namespace std;

const int MAXN = 101;
int n,m,cnt;
bool visit[MAXN];
int set[MAXN],order[MAXN],in[MAXN],out[MAXN];
vector
< vector<int> > adj;
vector
< vector<int> > radj;

void dfs(int u){
    visit[u]
=true;
    
int i,len=adj[u].size();
    
for(i=0;i<len;i++)
        
if(!visit[adj[u][i]])
            dfs(adj[u][i]);
    order[cnt
++]=u;
}

void rdfs(int u){
    visit[u]
=true;
    
set[u]=cnt;
    
int i,len=radj[u].size();
    
for(i=0;i<len;i++)
        
if(!visit[radj[u][i]])
            rdfs(radj[u][i]);
}

void korasaju(){
    
int i;
    memset(visit,
false,sizeof(visit));
    
for(cnt=0,i=1;i<=n;i++)
        
if(!visit[i])
            dfs(i);
    memset(visit,
false,sizeof(visit));
    
for(cnt=0,i=n-1;i>=0;i--)
        
if(!visit[order[i]])
            cnt
++,rdfs(order[i]);
}

int main(){
    
int i,j;
    scanf(
"%d",&n);
    adj.assign(n
+1,vector<int>());
    radj.assign(n
+1,vector<int>());
    
for(i=1;i<=n;i++){
        
while(scanf("%d",&m),m){
            adj[i].push_back(m);
            radj[m].push_back(i);
        }

    }

    korasaju();
    memset(
in,1,sizeof(in));
    memset(
out,1,sizeof(out));
    
for(i=1;i<=n;i++)
        
for(j=0;j<adj[i].size();j++)
            
if(set[i]!=set[adj[i][j]]){
                
out[set[i]]=0;
                
in[set[adj[i][j]]]=0;
            }

    
int ans1=0,ans2=0;
    
for(i=1;i<=cnt;i++){
        
if(out[i]) ans2++;
        
if(in[i]) ans1++;
    }

    
if(cnt==1){
        printf(
"1\n");
        printf(
"0\n");
    }

    
else{
        printf(
"%d\n",ans1);
        printf(
"%d\n",max(ans1,ans2));
    }

    
return 0;
}

posted on 2009-05-25 16:21 極限定律 閱讀(1365) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC

<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導航

統計

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

友情鏈接

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美在线视频一区二区三区| 欧美成人按摩| 久久视频精品在线| 亚洲无吗在线| 欧美乱人伦中文字幕在线| 在线看日韩欧美| 久久综合精品一区| 欧美一区二区三区视频免费播放 | 亚洲国产电影| 久久亚洲不卡| 狠狠色噜噜狠狠狠狠色吗综合| 亚洲男人av电影| 99视频精品免费观看| 午夜精品一区二区三区电影天堂 | 美女主播一区| 亚洲电影中文字幕| 欧美国产免费| 欧美黄色aa电影| aa亚洲婷婷| 在线性视频日韩欧美| 国产精品国产三级国产aⅴ浪潮| 中文成人激情娱乐网| 亚洲少妇一区| 国产亚洲毛片| 男女精品网站| 欧美日韩国产一区精品一区| 亚洲视频香蕉人妖| 亚洲欧美国产视频| 一区二区三区在线观看国产| 欧美成人免费观看| 欧美激情一区二区三区四区| 亚洲精品国产无天堂网2021| 亚洲精品婷婷| 亚洲人体一区| 亚洲国产99精品国自产| 欧美成熟视频| 一本色道**综合亚洲精品蜜桃冫| 日韩午夜免费视频| 国产农村妇女精品一区二区| 久久久久在线观看| 欧美成人亚洲| 先锋影音国产精品| 狠狠色丁香久久婷婷综合丁香 | 亚洲大胆美女视频| 久久国产精品亚洲va麻豆| 一本久久a久久免费精品不卡| 久久久久国产一区二区三区| 国产精品视频内| 一区二区三区国产在线| 欧美国产视频日韩| 久久一区激情| 免费不卡在线观看| 亚洲欧美区自拍先锋| 老司机精品福利视频| 午夜精品久久久久久久99热浪潮| 久久久水蜜桃av免费网站| 亚洲午夜av在线| 久久久久久网| 亚洲自拍偷拍麻豆| 免费久久精品视频| 久久久蜜桃一区二区人| 国产精品电影网站| 亚洲国产天堂久久综合网| 国产欧美在线看| 艳妇臀荡乳欲伦亚洲一区| 99视频精品全国免费| 韩国女主播一区| 在线视频日韩精品| 亚洲人成毛片在线播放女女| 久久9热精品视频| 亚洲一区自拍| 欧美日韩国产成人在线观看| 噜噜噜噜噜久久久久久91| 国产精品乱子久久久久| 亚洲美女黄网| 亚洲人成网站777色婷婷| 久久精品亚洲一区| 久久精品日韩欧美| 国产精品美女黄网| 夜夜嗨av色综合久久久综合网 | 久久性色av| 国产精品一区二区久久精品| 一本色道久久88综合亚洲精品ⅰ| 亚洲精品孕妇| 欧美在线视屏| 老鸭窝亚洲一区二区三区| 亚洲精品美女91| 亚洲综合国产| 最新成人在线| 亚洲精品午夜| 最新亚洲视频| 久久免费视频在线| 久久夜精品va视频免费观看| 国产在线精品一区二区中文 | 亚洲国产mv| 久久久精品日韩| 蜜桃av综合| 亚洲福利小视频| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美大片va欧美在线播放| 亚洲国产日韩欧美在线动漫| 久久综合久久久久88| 欧美激情一二区| 一区二区三区高清| 国产精品久久网| 欧美一区国产二区| 欧美a级理论片| 卡通动漫国产精品| 欧美国产日韩精品| 日韩亚洲一区在线播放| 欧美视频亚洲视频| 先锋影音久久久| 欧美激情区在线播放| 亚洲视频久久| 国产一区二区三区视频在线观看| 久久精品色图| 亚洲精品乱码久久久久| 午夜久久久久久| 狠狠爱www人成狠狠爱综合网| 男女精品网站| 在线亚洲国产精品网站| 久久久久九九九九| 99天天综合性| 国产欧美一区二区精品婷婷| 久久香蕉国产线看观看网| 99re6热只有精品免费观看| 久久不见久久见免费视频1| 亚洲福利视频网| 欧美影院视频| 亚洲国产精品热久久| 久久久久免费| 蜜桃久久av一区| 亚洲高清视频一区| 美女诱惑黄网站一区| 欧美成黄导航| 亚洲电影免费观看高清| 久久久久久久综合色一本| 久久青青草综合| 国产午夜精品麻豆| 久久国产高清| 久久这里只有| 亚洲激情偷拍| 欧美激情成人在线| 亚洲国产一区二区视频| 日韩午夜一区| 国产精品jizz在线观看美国 | 另类天堂av| 亚洲免费在线视频| 亚洲人成网站999久久久综合| 国产日韩欧美不卡在线| 欧美日韩国产在线播放| 国产日韩欧美综合精品| 亚洲高清精品中出| 欧美日韩成人免费| 亚洲国产一区二区三区高清| 久久视频在线看| 欧美一区二区三区电影在线观看| 亚洲三级视频| 在线观看欧美激情| 国产亚洲一区二区三区在线播放| 欧美日韩免费高清一区色橹橹| 久久久精品2019中文字幕神马| 亚洲一区二区三区在线观看视频 | 欧美暴力喷水在线| 久久九九电影| 欧美一区二区三区在线看| 亚洲午夜精品网| 一区二区三区欧美视频| 亚洲国产综合91精品麻豆| 欧美电影免费观看| 欧美成人xxx| 欧美va亚洲va香蕉在线| 久久综合网hezyo| 久久久精品国产免大香伊| 久久精品99国产精品| 午夜精彩视频在线观看不卡| 亚洲无玛一区| 亚洲免费在线播放| 亚洲欧美日韩综合aⅴ视频| 一区二区精品国产| 正在播放亚洲| 亚洲永久免费精品| 午夜在线精品偷拍| 久久精品卡一| 免费成人高清| 欧美国产综合一区二区| 91久久亚洲| 日韩视频一区| 亚洲一区二区三区四区中文 | 欧美精品v日韩精品v韩国精品v | 国产伦精品一区二区三区视频孕妇 | 欧美激情久久久久| 欧美日在线观看| 国产精品在线看| 黄色成人av| 亚洲精品少妇30p| 亚洲欧美日韩精品久久亚洲区 | 久久影院午夜论| 欧美黄色大片网站| 亚洲理伦在线|