• <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>
            隨筆-72  評論-126  文章-0  trackbacks-0
            http://acm.pku.edu.cn/JudgeOnline/problem?id=2724
             1 #include<stdio.h>
             2 #include<string.h>
             3 #define M 1024
             4 int chess[M];
             5 int hh[M][M];
             6 int link[M];
             7 char visit[M];
             8 char num[M];
             9 int to_10(char *a)
            10 {
            11     int n=0;
            12     for(;*a;a++)
            13         n = n*2 + (*a)-'0';
            14     return n;
            15 }
            16 int pipei(int n)
            17 {
            18     return (n&&((n&(n-1))==0));
            19 }
            20 int find(int a,int m)
            21 {
            22     int b;
            23     for(b=0;b<m;b++)
            24     {
            25         if(hh[a][b]&&!visit[b])
            26         {
            27             visit[b]=1;
            28             if(link[b]==-1||find(link[b],m)) 
            29             {
            30                 link[b] = a;
            31                 return 1;
            32             }
            33         }
            34     }
            35     return 0;
            36 }
            37 int main()
            38 {
            39     int n,m,i,k,a,b,max,count;
            40     char str1[100],str2[100];
            41     while (scanf("%d%d%",&n,&m),n+m)
            42     {
            43         k = 0;
            44         memset(num,0,sizeof(num));
            45         while(m--)
            46         {
            47             scanf("%s",str1);
            48             for(i=0;str1[i];i++)
            49                 if(str1[i]=='*')
            50                     break;
            51                 if(str1[i])
            52                 {
            53                     strcpy(str2,str1);
            54                     str1[i] = '0';
            55                     str2[i] = '1';
            56                     num[to_10(str1)] = 1;
            57                     num[to_10(str2)] = 1;
            58                 }
            59                 else
            60                     num[to_10(str1)] = 1;
            61         }
            62         max = 1<<n;
            63         for(i=0;i<max;i++)
            64             if(num[i])
            65                 chess[k++]=i;
            66         for(a=0;a<k;a++)
            67         {
            68             for(b=0;b<k;b++)
            69             {
            70                 if(a==b)
            71                     continue;
            72                 hh[a][b] = pipei(chess[a]^chess[b]);
            73             }
            74         }
            75         memset(link,-1,sizeof(link));
            76         count = 0;
            77         for(i=0;i<k;i++)
            78         {
            79             memset(visit,0,sizeof(visit));
            80             count += find(i,k);
            81         }
            82         printf("%d\n",k-count/2);
            83     }
            84     return 0;
            85 }
            86 
            87 

             二分模板http://acm.hdu.edu.cn/showproblem.php?pid=2119
            #include<stdio.h>
            #include
            <string>
            #define M 101
            int map[M][M];
            int visit[M];
            int link[M];
            int n,m;
            int find(int a)
            {
                
            int b;
                
            for(b=0;b<m;b++)
                {
                    
            if(map[a][b] && !visit[b])
                    {
                        visit[b] 
            = 1;
                        
            if(link[b]==-1 || find(link[b]))
                        {
                            link[b] 
            = a;
                            
            return 1;
                        }
                    }
                }
                
            return 0;
            }
            int match()
            {
                
            int sum=0,i;
                memset(link,
            -1,sizeof(link));
                
            for(i=0;i<n;i++)
                {
                    memset(visit,
            0,sizeof(visit));
                    sum 
            += find(i);
                }
                
            return sum;
            }
            int main()
            {
                
            int i,j;
                
            while(scanf("%d",&n),n)
                {
                    scanf(
            "%d",&m);
                    
            for(i=0;i<n;i++)
                        
            for(j=0;j<m;j++)
                            scanf(
            "%d",&map[i][j]);
                    printf(
            "%d\n",match());
                }
                
            return 0;
            }

            posted on 2009-02-09 22:43 shǎ崽 閱讀(338) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            伊人久久综合成人网| 国产成人精品久久一区二区三区| 大美女久久久久久j久久| 久久精品国产99国产精偷| 97超级碰碰碰碰久久久久 | 日韩欧美亚洲国产精品字幕久久久 | 欧美精品九九99久久在观看| 久久午夜无码鲁丝片秋霞| 久久国产精品一国产精品金尊| a级毛片无码兔费真人久久| 亚洲午夜久久久| 久久久国产精品网站| 久久久无码精品亚洲日韩京东传媒| 久久综合噜噜激激的五月天| 精品人妻伦九区久久AAA片69| 亚洲综合日韩久久成人AV| 国产亚洲色婷婷久久99精品91| 久久综合噜噜激激的五月天| 色悠久久久久久久综合网| 国产精品一区二区久久精品无码| 狠狠色婷婷久久一区二区| 国产伊人久久| 97精品伊人久久久大香线蕉| 久久精品蜜芽亚洲国产AV| 久久经典免费视频| 久久免费国产精品| 国产福利电影一区二区三区久久老子无码午夜伦不 | 天天做夜夜做久久做狠狠| 国内精品久久国产大陆| 中文字幕久久久久人妻| 99久久综合国产精品免费| 久久久久国产精品麻豆AR影院| 久久久久久免费一区二区三区| 91精品国产综合久久久久久| 午夜人妻久久久久久久久| 久久久无码精品亚洲日韩蜜臀浪潮| 色婷婷狠狠久久综合五月| 欧美日韩精品久久久久| 人人狠狠综合88综合久久| 老司机午夜网站国内精品久久久久久久久 | 午夜精品久久久久久影视riav|