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

  • 相关阅读:
    NodeJS第4天笔记
    NodeJS第3天笔记
    NodeJS第3天笔记
    NodeJS第3天笔记
    NodeJS第2天笔记
    NodeJS第1天笔记
    6、开发工具webstorm添加多个项目
    5、MongoDB索引
    4、mongodb更改字段类型
    mongodb安装和使用备忘
  • 原文地址:https://www.cnblogs.com/xryz/p/4847805.html
Copyright © 2020-2023  润新知