• <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了,總是卡水題,悲劇啊
            久久亚洲国产中v天仙www| 久久91这里精品国产2020| 7777久久久国产精品消防器材| 一本色道久久综合狠狠躁| 久久久久高潮毛片免费全部播放 | 亚洲国产二区三区久久| 亚洲а∨天堂久久精品| 久久精品无码专区免费东京热| 嫩草影院久久国产精品| 久久精品国产99久久久古代| 色噜噜狠狠先锋影音久久| 亚洲精品乱码久久久久久蜜桃不卡 | 久久久久久综合一区中文字幕| 久久久久久亚洲精品不卡| 婷婷五月深深久久精品| 女同久久| 久久久精品久久久久久| 久久综合丝袜日本网| 久久综合噜噜激激的五月天| 久久久久亚洲av成人无码电影| 国产情侣久久久久aⅴ免费| 国产精品久久久久久久人人看| 狠狠精品干练久久久无码中文字幕 | 性欧美大战久久久久久久| 国产精品久久久久久久久久免费| 久久精品天天中文字幕人妻| 久久这里只有精品视频99| 日韩亚洲欧美久久久www综合网| 伊人久久无码精品中文字幕| 狠狠色婷婷综合天天久久丁香| 国产精品久久亚洲不卡动漫| 久久国产亚洲精品| 亚洲天堂久久精品| 国产亚洲欧美精品久久久| 无码AV中文字幕久久专区| 99久久香蕉国产线看观香| 久久国产影院| 久久久久18| 久久精品成人免费看| 久久综合国产乱子伦精品免费| 三级三级久久三级久久|