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

            Uriel's Corner

            Research Associate @ Harvard University / Research Interests: Computer Vision, Biomedical Image Analysis, Machine Learning
            posts - 0, comments - 50, trackbacks - 0, articles - 594

            POJ 3715 Blue and Red---二分圖匹配

            Posted on 2010-08-08 19:34 Uriel 閱讀(399) 評論(0)  編輯 收藏 引用 所屬分類: POJ圖論
            想到二分圖,但是不知道那種貪心思想對不對以及如何優化。。參考了解題報告

            感謝大牛的解題報告:http://hi.baidu.com/liuzhe/blog/item/793e0c24efa6602cd407428a.html

            基本上照著寫的,然后加了讀入輸出優化,效果驚人。。0MS。。暫時Rank1了。。還是頭一次刷到這么前。。

            //Problem: 3715  User: Uriel 
            //Memory: 444K  Time: 0MS 
            //Language: G++  Result: Accepted
            //Bipartite Graph Matching
            //Hungary
            //2010.08.08

            #include
            <stdio.h>
            #include
            <stdlib.h>
            #include
            <string.h>

            short n,m,index;
            bool type[205],a[205][205];
            short l[205],ln;

            struct node{
                
            short id;
                node 
            *next;
            }
            *head[205],table[30005];

            inline 
            void add(int x,int y){
                table[index].id
            =y;
                table[index].next
            =head[x];
                head[x]
            =&table[index];
                index
            ++;
            }


            int in()
            {
                
            char ch;
                
            int a=0;
                
            while((ch=getchar())==' ' || ch=='\n');
                a
            *=10;
                a
            +=ch-'0';
                
            while((ch=getchar())!=' ' && ch!='\n')
                
            {
                    a
            *=10;
                    a
            +=ch-'0';
                }

                
            return a;
            }


            void out(int a)
            {
                
            if(a>=10)out(a/10);
                putchar(a
            %10+'0');
            }


            void Build_Graph(){
                n
            =in();m=in();
                
            int i;
                ln
            =index=0;
                
            for(i=1;i<=n;i++){
                    type[i]
            =in();
                    
            if(!type[i])l[++ln]=i;
                }

                memset(a,
            0,sizeof(a));
                memset(head,
            0,sizeof(head));
                
            for(i=1;i<=m;i++){
                    
            int x,y;
                    x
            =in();y=in();
                    
            ++x,++y;
                    
            if(type[x]!=type[y] && !a[x][y]){
                        a[x][y]
            =a[y][x]=1;
                        add(x,y);
                        add(y,x);
                    }

                }

            }


            short lx[205],ly[205];
            bool flag[205],del[205];

            bool find(int x){
                flag[x]
            =1;
                
            for(node *p=head[x];p;p=p->next)
                
            if(!flag[p->id] && !del[p->id]){
                     flag[p
            ->id]=1;
                     
            if(!lx[p->id] || find(lx[p->id])){
                         lx[p
            ->id]=x;
                         ly[x]
            =p->id;
                         
            return 1;
                     }

                }

                
            return 0;
            }


            bool dfs1(int x){
                flag[x]
            =1;
                
            for(node *p=head[x];p;p=p->next)
                
            if(!flag[p->id] && !del[p->id]){
                     flag[p
            ->id]=1;
                     
            if(!lx[p->id] || dfs1(lx[p->id]))
                     
            return 1;
                }

                
            return 0;
            }


            bool dfs2(int x){
                flag[x]
            =1;
                
            for(node *p=head[x];p;p=p->next)
                
            if(!flag[p->id] && !del[p->id]){
                     flag[p
            ->id]=1;
                     
            if(!ly[p->id] || dfs2(ly[p->id]))
                     
            return 1;
                }

                
            return 0;
            }


            int hungary(){
                memset(lx,
            0,sizeof(lx));
                memset(ly,
            0,sizeof(ly));
                
            int i,ans=0;
                
            for(i=1;i<=ln;i++)
                    
            if(!del[l[i]]){
                        memset(flag,
            0,sizeof(flag));
                        
            if(find(l[i]))ans++;
                    }

                
            return ans;
            }


            void Sov(){
                memset(del,
            0,sizeof(del));
                
            int i,max=hungary();
                
            out(max);
                
            for(i=1;i<=&& max;i++){
                    
            if(!lx[i] && !ly[i])continue;
                    
            else if(lx[i]){
                        memset(flag,
            0,sizeof(flag));
                        del[i]
            =1;
                        
            if(!dfs1(lx[i])){
                            max
            --;
                            ly[lx[i]]
            =0;
                            putchar(
            ' ');
                            
            out(i-1);
                        }

                        
            else
                            del[i]
            =0;
                    }

                    
            else if(ly[i]){
                        memset(flag,
            0,sizeof(flag));
                        del[i]
            =1;
                        
            if(!dfs2(ly[i])){
                            max
            --;
                            lx[ly[i]]
            =0;
                            putchar(
            ' ');
                            
            out(i-1);
                        }

                        
            else
                            del[i]
            =0;
                    }

                }

                puts(
            "");
            }


            int main(){
                
            int t;
                t
            =in();
                
            while(t--){
                     Build_Graph();
                     Sov();
                }

                
            return 0;
            }

            神一樣的讀入輸出優化~~~

            PS:圖論的建圖還是糾結,但是悲劇的是比賽的時候往往遇到稍微麻煩點的圖論還沒開始糾結比賽就已經over了,總是卡水題,悲劇啊
            久久精品无码一区二区三区免费| 人妻精品久久久久中文字幕69 | 精产国品久久一二三产区区别 | 国产精品成人精品久久久| 国产精品伦理久久久久久| 亚洲人成电影网站久久| 人妻无码久久一区二区三区免费| 国产精品青草久久久久婷婷| 久久久精品视频免费观看| 精品国产99久久久久久麻豆| 国产精品一久久香蕉产线看| 久久久无码精品午夜| 久久亚洲AV成人无码国产| 亚洲国产天堂久久久久久| 久久91精品久久91综合| 久久精品国产亚洲AV不卡| 国产精品久久久天天影视香蕉| 亚洲午夜久久久久久久久电影网| 99精品伊人久久久大香线蕉| 狠狠色丁香婷婷久久综合| 国产AV影片久久久久久| 99久久国产综合精品麻豆| 亚洲中文字幕久久精品无码喷水 | 91精品国产色综久久| 国内精品久久久久影院日本| 久久精品国产亚洲αv忘忧草 | 亚洲精品乱码久久久久久| 久久综合亚洲色HEZYO国产| 久久婷婷久久一区二区三区| 99蜜桃臀久久久欧美精品网站 | 久久国产色av免费看| 青青草原综合久久大伊人导航| 久久精品这里热有精品| 狠狠色丁香婷婷久久综合不卡| 日韩av无码久久精品免费| 亚洲综合精品香蕉久久网| 亚洲欧洲日产国码无码久久99| 伊人久久精品影院| 国产A级毛片久久久精品毛片| 97精品伊人久久大香线蕉| 中文字幕日本人妻久久久免费 |