• <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 閱讀(418) 評論(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了,總是卡水題,悲劇啊
            少妇久久久久久被弄到高潮 | 久久综合九色综合久99 | 亚洲精品无码久久久久久| 国产99久久精品一区二区| 国产午夜精品理论片久久| 久久久精品久久久久影院| 国产高潮国产高潮久久久| 青青热久久国产久精品 | 亚洲第一极品精品无码久久| 国产福利电影一区二区三区,免费久久久久久久精 | 狠狠色丁香婷婷综合久久来| 亚洲国产成人久久笫一页| 久久精品一区二区三区不卡| 91麻豆国产精品91久久久| 亚洲国产成人久久综合碰碰动漫3d| 久久久久久久久久久精品尤物| 国产综合免费精品久久久| 久久久久亚洲av无码专区导航| 中文字幕精品无码久久久久久3D日动漫| 久久精品国产一区| AV狠狠色丁香婷婷综合久久| 性欧美丰满熟妇XXXX性久久久 | 999久久久国产精品| 久久久无码一区二区三区| 久久精品国产2020| 色婷婷久久久SWAG精品| 国产福利电影一区二区三区,免费久久久久久久精 | 亚洲国产日韩欧美久久| 久久精品视屏| 国产精品99久久久久久董美香| 久久91精品国产91久久麻豆| 国产精品女同久久久久电影院| 亚洲AV成人无码久久精品老人| 亚洲精品午夜国产VA久久成人| 99久久精品免费看国产一区二区三区| 亚洲美日韩Av中文字幕无码久久久妻妇| 精品久久久久一区二区三区| 国产一区二区精品久久凹凸| 日韩精品无码久久一区二区三| 亚洲精品第一综合99久久| 久久亚洲AV成人无码软件|