• <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>

            Ural 1080 Map Colouring

            1080. Map Colouring

            Time Limit: 1.0 second
            Memory Limit: 16 MB
            We consider a geographical map with N countries numbered from 1 to N (0 < N < 99). For every country we know the numbers of other countries which are connected with its border. From every country we can reach to any other one, eventually crossing some borders. Write a program which determines whether it is possible to colour the map only in two colours — red and blue in such a way that if two countries are connected their colours are different. The colour of the first country is red. Your program must output one possible colouring for the other countries, or show, that such colouring is impossible.

            Input

            On the first line is written the number N. On the following N lines, the i-th line contains the countries to which the i-th country is connected. Every integer on this line is bigger than i, except the last one which is 0 and marks that no more countries are listed for country i. If a line contains 0, that means that the i-th country is not connected to any other country, which number is larger than i.

            Output

            The output contains exactly one line. If the colouring is possible, this line must contain a list of zeros and ones, without any separators between them. The i-th digit in this sequence is the colour of the i-th country. 0 corresponds to red colour, and one — to blue colour. If a colouring is not possible, output the integer −1.

            Sample

            input output
            3
                                    2 0
                                    3 0
                                    0
                                    
            010
                                    

            DFS:或BFS,或者并查集(不會用)
            這里用的DFS,用一個標記數組,沒進入一個聯通分圖后,標記為0(表示一種顏色)與它相連的標記為1(另一種顏色),
            然后與1相連的在標記為0。 這里的標記都是對沒有標記過的進行的,如果是標記過的,就要檢查他們的標記是否相同
            如果相同則說明,他們同色。
            //ural 1080
            #include<iostream>
            using namespace std;

            const int MAX=100;
            bool adj[MAX][MAX];
            int flg[MAX];
            int n;
            bool isPossible=true;

            void input()
            {
                 cin
            >>n;
                 
            int temp;
                 
            for(int i=1; i<=n; i++)
                 {
                         
            while(cin>>temp,temp!=0)
                         {
                                                 adj[i][temp]
            =adj[temp][i]=true;
                         }
                 }
            }

            void dfs(int i)
            {
                 
            if(isPossible==false)return ;
                 
            if(flg[i]==-1)flg[i]=0;
                 
            for(int j=1; j<=n; j++)
                 {
                         
            if(adj[i][j])
                         {
                                      
            if(flg[j]==-1){ flg[j]=flg[i]==0? 1:0;  dfs(j); } 
                                      
            else if(flg[j]==flg[i])isPossible=false;
                                      
                         }
                 }
                 
            }

            int main()
            {
                memset(adj,
            0,sizeof adj);
                
                input();
                
            for(int i=1; i<=n; i++
                       flg[i]
            =-1;  
                
                flg[
            1]=0;
                
            for(int i=1; i<=n; i++)
                        dfs(i);
                
                
            if(isPossible==false)cout<<-1<<endl;
                
            else { 
                     
            for(int k=1; k<=n; k++)
                         cout
            <<flg[k];
                     cout
            <<endl;
                       }
                         
                
                system(
            "pause");
                
            return 0;
            }

            posted on 2010-07-31 17:17 田兵 閱讀(288) 評論(0)  編輯 收藏 引用 所屬分類: URAL

            <2010年8月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            導航

            統計

            常用鏈接

            留言簿(2)

            隨筆分類(65)

            隨筆檔案(65)

            文章檔案(2)

            ACM

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            久久人人爽人人爽人人爽| 91秦先生久久久久久久| 一本大道久久香蕉成人网| 亚洲欧美久久久久9999| 亚洲精品无码成人片久久| 99精品久久精品一区二区| 99久久婷婷国产综合精品草原| 久久综合精品国产一区二区三区| 久久九九兔免费精品6| 久久国产亚洲精品无码| 国产亚洲成人久久| 人妻少妇久久中文字幕一区二区| 国产精品美女久久久网AV| 久久久久久综合网天天| segui久久国产精品| 久久精品国产第一区二区三区| 久久久久18| 国产高清国内精品福利99久久| 免费精品久久天干天干| 国产精久久一区二区三区| 色欲av伊人久久大香线蕉影院| 欧美日韩中文字幕久久久不卡| 精品熟女少妇a∨免费久久| 久久久久se色偷偷亚洲精品av| 国产AV影片久久久久久| 国产精品久久免费| 国产午夜精品久久久久免费视| 精品久久人人爽天天玩人人妻| 亚洲国产成人久久一区WWW| 精品欧美一区二区三区久久久| 国产精品美女久久久久网| 久久精品国产亚洲av高清漫画| 久久人人爽人人爽人人片AV不 | 香蕉久久夜色精品升级完成| 久久久久久亚洲精品无码| 久久久精品久久久久久| 久久国产精品视频| 久久人人爽人人爽人人片AV东京热| 一本大道加勒比久久综合| 中文字幕成人精品久久不卡| 99久久精品九九亚洲精品|