zoukankan      html  css  js  c++  java
  • zoj 1654 Place the Robots 二分图匹配DFS实现

    #include<bits/stdc++.h>
    using namespace std;
    const int N=2500+5;
    char mp[128][128];
    int xs[128][128],ys[128][128];
    int nx,ny,cx[N],cy[N],g[N][N],mk[N];
    
    int path(int u)
    {
        for(int v=1; v<=ny; v++)
        {
            if(g[u][v]&&!mk[v])
            {
                mk[v]=1;
                if(cy[v]==-1||path(cy[v]))
                {
                    cx[u]=v;
                    cy[v]=u;
                    return 1;
                }
            }
        }
        return 0;
    }
    
    int MaxMatch()
    {
        int res=0;
        memset(cx,0xff,sizeof(cx));
        memset(cy,0xff,sizeof(cy));
        for(int i=1; i<=nx; i++)
        {
            if(cx[i]==-1)
            {
                memset(mk,0,sizeof(mk));
                res+=path(i);
            }
        }
        return res;
    }
    
    int main()
    {
        int i,j,_,k,n,m,st;
        scanf("%d",&_);
        for(k=1; k<=_; k++)
        {
            scanf("%d%d",&n,&m);
            for(i=0;i<n;i++)
                scanf("%s",mp[i]);
            memset(xs,0,sizeof(xs));
            memset(ys,0,sizeof(ys));
            memset(g,0,sizeof(g));
            nx=0;
            for(i=0;i<n;i++)
            {
                st=0;
               for(j=0;j<m;j++)
               {
                   if(mp[i][j]=='o')
                   {
                       if(st==0) nx++;
                        xs[i][j]=nx;
                        st=1;
                   }
                   else if(mp[i][j]=='#') st=0;
               }
            }
            ny=0;
            for(j=0;j<m;j++)
            {
                st=0;
                for(i=0;i<n;i++)
                {
                    if(mp[i][j]=='o')
                   {
                       if(st==0) ny++;
                        ys[i][j]=ny;
                        st=1;
                   }
                   else if(mp[i][j]=='#') st=0;
                }
            }
            for(i=0;i<n;i++)
            {
                for(j=0;j<m;j++)
                {
                    if(xs[i][j])
                        g[xs[i][j]][ys[i][j]]=1;
                }
            }
            /*for(i=0;i<=nx;i++)
            {
                for(j=0;j<=ny;j++)
                {
                    printf("%d ",g[i][j]);
                }
                printf("
    ");
            }*/
            printf("Case :%d
    %d
    ",k,MaxMatch());
        }
        return 0;
    }

    版权声明:本文为博主原创文章,未经博主允许不得转载。http://xiang578.top/

  • 相关阅读:
    最长回文子串(马拉车)
    ubutun 启动/停止/重启MySQL数据库
    臭大佬_LZW
    Beauty Contest(求凸包最大直径)
    Smallest Bounding Rectangle(最小面积外接矩形)
    Triangle(求凸包最大内接三角形)
    P4196 [CQOI2006]凸多边形
    P4724 【模板】三维凸包(简洁)
    P2600 [ZJOI2008]瞭望塔【半平面交】
    退役记
  • 原文地址:https://www.cnblogs.com/xryz/p/4847805.html
Copyright © 2011-2022 走看看