二分图板子

原理:

匈牙利算法:二分图最大权匹配 - OI Wiki

简单说就是挨个找,找到就退出。后面的来了就让前面的挪位置。

板子: 

book指给u找位置时,有人考虑过的位置就不考虑了。

match[ i ]就是i位置对应的人。

e是关系

int book[10001];
int match[10001];
bool e[101][101];
int ans=0,n=0,m=0;
bool dfs(int u)
{
    for(int i=1;i<=n;i++)
    {
        if(book[i]==0 && e[u][i]==true)
        {
            book[i]=1;
            if(match[i]==0 || dfs(match[i])==true)
            {
                match[u]=i;
                match[i]=u;
                return true;
            }
        }
    }
    return false;
}

使用:

int main()
{
    scanf("%d %d",&n,&m);
    for(int i=1;i<=m;i++)
    {
        int x=0,y=0;
        scanf("%d %d",&x,&y);
        e[x][y]=true;
        e[y][x]=true;
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            book[j]=0;
        }
        if(dfs(i)==true)
        {
            ans++;
        }
    }
    printf("%d",ans);
    return 0;
}

相关推荐

  1. 二分板子

    2024-02-03 01:48:02       55 阅读
  2. <span style='color:red;'>二分</span><span style='color:red;'>图</span>

    二分

    2024-02-03 01:48:02      44 阅读
  3. 二分 染色法 + 匈牙利算法

    2024-02-03 01:48:02       49 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-03 01:48:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-03 01:48:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-03 01:48:02       87 阅读
  4. Python语言-面向对象

    2024-02-03 01:48:02       96 阅读

热门阅读

  1. numpy的学习之1

    2024-02-03 01:48:02       53 阅读
  2. Android 8.1 输入框返回键改为删除功能

    2024-02-03 01:48:02       52 阅读
  3. 面试手写第三期

    2024-02-03 01:48:02       55 阅读
  4. 网络通信--术语对照表

    2024-02-03 01:48:02       53 阅读
  5. ubuntu安装redis记录

    2024-02-03 01:48:02       63 阅读
  6. QT 加载 mysql 驱动

    2024-02-03 01:48:02       57 阅读
  7. 【笔记】SPN和PLMN 运营商网络名称显示

    2024-02-03 01:48:02       120 阅读
  8. <网络安全>《13 上网行为管理》

    2024-02-03 01:48:02       55 阅读
  9. SpringCloud引入父项目需要注意的地方

    2024-02-03 01:48:02       53 阅读