• <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>
            posts - 74,  comments - 33,  trackbacks - 0

            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

            IOI 1996
            很好的一道題目寫了一下Tarjan算法求聯通度,沒想到的是
            #include<cstdio>
            #include
            <cstring>
            #include
            <stack>
            #include
            <vector>
            #define?MAXN?120
            using?namespace?std;
            int?pre[MAXN],low[MAXN],id[MAXN];
            int?cnt,scnt,n,m,k;
            vector
            <int>v[MAXN];
            bool?markin[MAXN],markout[MAXN];
            stack
            <int>ST;
            void?Tarjan(int?x){
            ????
            int?t,i;
            ????
            int?min=low[x]=pre[x]=cnt++;
            ????ST.push(x);
            ????
            for(i=0;i<v[x].size();i++){
            ????????t
            =v[x][i];
            ????????
            if(pre[t]==-1)Tarjan(t);
            ????????
            if(low[t]<min)min=low[t];
            ????}

            ????
            if(min<low[x]){
            ????????low[x]
            =min;
            ????????
            return;
            ????}

            ????
            do{
            ????????id[t
            =ST.top()]=scnt;
            ????????low[t]
            =n;ST.pop();
            ????}
            while(t!=x);
            ????scnt
            ++;
            }

            int?SCC(){
            ????scnt
            =cnt=0;
            ????memset(pre,
            0xff,sizeof(pre));
            ????memset(low,
            0,sizeof(low));
            ????
            for(int?i=0;i<n;i++)
            ????????
            if(pre[i]==-1)Tarjan(i);
            ????
            return?scnt;
            }

            int?main(){
            ????
            int?i,j,a;
            ????
            while(scanf("%d",&n)!=EOF){
            ????????
            for(i=0;i<n;i++)v[i].clear();
            ????????
            for(i=0;i<n;i++){
            ????????????
            while(scanf("%d",&a)&&a)
            ????????????????v[i].push_back(a
            -1);
            ????????}

            ????????k
            =SCC();
            ????????memset(markin,
            0,sizeof(markin));
            ????????memset(markout,
            0,sizeof(markout));
            ????????
            int?sum_F=0,sum_S=0;
            ????????
            for(i=0;i<n;i++)
            ????????????
            for(j=0;j<v[i].size();j++)
            ????????????????
            if(id[i]!=id[v[i][j]]){
            ????????????????????markout[id[i]]
            =true;
            ????????????????????markin[id[v[i][j]]]
            =true;
            ????????????????}

            ????????
            for(i=0;i<k;i++){
            ????????????
            if(!markin[i])sum_F++;
            ????????????
            if(!markout[i])sum_S++;
            ????????}

            ????????printf(
            "%d\n",sum_F);
            ????????
            if(sum_F==1&&sum_S==1)printf("0\n");
            ????????
            else?printf("%d\n",sum_F>sum_S?sum_F:sum_S);
            ????}

            }

            這樣是錯的,不知道為什么 ,最后把if(sum_F==1&&sum_S==1)printf("0\n");
            改成了if(k==1)printf("0\n");就AC了。實在是不懂為什么呢 ,其實這兩個條件應該是等價的
            當最后縮成只有一個點的時候必然存在sum_F入度等于出度sum_S等于1。
            所以說比較郁悶。。。。
            posted on 2009-05-13 16:45 KNIGHT 閱讀(202) 評論(1)  編輯 收藏 引用

            FeedBack:
            # re: Network of Schools
            2009-05-14 07:24 | Knight
            感謝zju的HH神牛,謝謝 HH神牛的數據2個點 a->b
            2
            2 0
            0
            對于in==1&&out==1但是scc==2


              回復  更多評論
              
            <2011年8月>
            31123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(8)

            隨筆檔案

            文章檔案

            Friends

            OJ

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品九九久久精品女同亚洲欧美日韩综合区 | 亚洲精品高清国产一久久| 国产精品一区二区久久精品| 色综合久久综精品| 久久人人爽人人爽人人片AV东京热 | 久久精品国产亚洲精品| 久久亚洲国产精品成人AV秋霞 | 2019久久久高清456| 91精品国产综合久久久久久| 亚洲国产成人久久精品99| 少妇人妻88久久中文字幕| 国产精品欧美久久久久无广告| 久久国产精品无| 国产成人精品久久综合| 久久国产精品无码一区二区三区| 欧美日韩成人精品久久久免费看| 精品久久久噜噜噜久久久| 一本一道久久a久久精品综合| 久久精品国产亚洲AV无码麻豆| 久久久久亚洲AV无码专区桃色| 国产99精品久久| 99久久久精品免费观看国产| 国产A级毛片久久久精品毛片| 久久精品国产精品亚洲人人| 久久99精品国产麻豆宅宅| 久久精品午夜一区二区福利| 国产精品久久久久久久人人看| 久久久91人妻无码精品蜜桃HD| 国产精品久久自在自线观看| 久久久久免费看成人影片| 中文字幕日本人妻久久久免费| 精品一二三区久久aaa片| 狠狠色丁香久久婷婷综合| 色综合久久中文字幕综合网| 青青草国产97免久久费观看| 精品人妻伦一二三区久久| 精品久久久久国产免费| 久久国产精品视频| 污污内射久久一区二区欧美日韩 | 亚洲乱码日产精品a级毛片久久| 久久亚洲精品无码播放|