题意:求二分图的最大匹配数量

模版如下:

//二分图匹配(匈牙利算法的DFS实现)
//初始化:g[][]两边顶点的划分情况
//建立g[i][j]表示i->j的有向边就可以了,是左边向右边的匹配
//g没有边相连则初始化为0
//uN是匹配左边的顶点数,vN是匹配右边的顶点数
//调用:res=hungary();输出最大匹配数
//优点:适用于稠密图,DFS找增广路,实现简洁易于理解
//时间复杂度:O(VE)
//*******************
#include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <sstream>
#include <queue>
#include <typeinfo>
#include <fstream>
typedef long long ll;
using namespace std;
//freopen("D.in","r",stdin);
//freopen("D.out","w",stdout);
const int MAXN=510;
int uN,vN;//u,v数目
int g[MAXN][MAXN];
int linker[MAXN];
bool used[MAXN];
bool dfs(int u)//从左边开始找增广路径
{int v;for(v=0;v<vN;v++)//这个顶点编号从0开始,若要从1开始需要修改if(g[u][v]&&!used[v]){used[v]=true;if(linker[v]==-1||dfs(linker[v])){//找增广路,反向linker[v]=u;return true;}}return false;//这个不要忘了,经常忘记这句
}
int hungary()
{int res=0;int u;memset(linker,-1,sizeof(linker));for(u=0;u<uN;u++){memset(used,0,sizeof(used));if(dfs(u)) res++;}return res;
}

A题代码:

#include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <sstream>
#include <queue>
#include <typeinfo>
#include <fstream>
typedef long long ll;
using namespace std;
//freopen("D.in","r",stdin);
//freopen("D.out","w",stdout);
const int MAXN=510;
int uN,vN;//u,v数目
int g[MAXN][MAXN];
int linker[MAXN];
bool used[MAXN];
bool dfs(int u)//从左边开始找增广路径
{int v;for(v=0;v<vN;v++)//这个顶点编号从0开始,若要从1开始需要修改if(g[u][v]&&!used[v]){used[v]=true;if(linker[v]==-1||dfs(linker[v])){//找增广路,反向linker[v]=u;return true;}}return false;//这个不要忘了,经常忘记这句
}
int hungary()
{int res=0;int u;memset(linker,-1,sizeof(linker));for(u=0;u<uN;u++){memset(used,0,sizeof(used));if(dfs(u)) res++;}return res;
}
int main()
{memset(g,0,sizeof(g));int b[MAXN],g1[MAXN];cin>>uN;for(int i=0;i<uN;i++)cin>>b[i];cin>>vN;for(int i=0;i<vN;i++)cin>>g1[i];for(int i=0;i<uN;i++){for(int j=0;j<vN;j++){if(fabs(b[i]-g1[j])<=1)g[i][j]=1;}}cout<<hungary()<<endl;return 0;
}

CF 277.5 B.BerSU Ball 二分图的最大匹配 模版题相关推荐

  1. 用匈牙利算法求二分图的最大匹配

    转载大神的!! 什么是二分图,什么是二分图的最大匹配,这些定义我就不讲了,网上随便都找得到.二分图的最大匹配有两种求法,第一种是最大流(我在此假设读者已有网络流的知识):第二种就是我现在要讲的匈牙利算 ...

  2. 二分图的最大匹配 匈牙利算法

    基本概念 1.二分图: 二分图又称作二部图,是图论中的一种特殊模型. 设G=(V,E)是一个无向图,如果顶点V可分割为两个互不相交的子集(A,B),并且图中的每条边(i,j)所关联的两个顶点i和j分别 ...

  3. DAG的最小路径覆盖和二分图的最大匹配

    DAG的最小路径覆盖和二分图的最大匹配 DAG的最小路径覆盖是指找最小数目的互相不相交的有向路径,满足DAG的所有顶点都被覆盖. 首先给出公式:DAG的最小路径覆盖数=DAG图中的节点数-相应二分图中 ...

  4. POJ 2584 T-Shirt Gumbo (二分图多重最大匹配)

    题意 现在要将5种型号的衣服分发给n个参赛者,然后给出每个参赛者所需要的衣服的尺码的大小范围,在该尺码范围内的衣服该选手可以接受,再给出这5种型号衣服各自的数量,问是否存在一种分配方案使得每个选手都能 ...

  5. 二分图的最大匹配-解决匹配问题

    题目描述 题目描述 若两个正整数的和为素数,则这两个正整数称之为"素数伴侣",如2和5.6和13,它们能应用于通信加密.现在密码学会请你设计一个程序,从已有的N(N为偶数)个正整数 ...

  6. 【网络流】基础二分图的最大匹配问题

    标题已经说了,所以有基础的牛们就别想在这篇博客里看到什么有价值的东西.这里的解法是最基础的. 二分图是一种可以把图中的点分为两个不同的集合,且同一集合中不存在任意两个有边联通的点(就算是单向边也不行) ...

  7. Jamie's Contact Groups ——(一对多)二分图多重最大匹配

    题目链接:http://poj.org/problem?id=2289 Jamie is a very popular girl and has quite a lot of friends, so ...

  8. 861. 二分图的最大匹配

    861. 二分图的最大匹配 给定一个二分图,其中左半部包含 n1 个点(编号 1∼n1),右半部包含 n2 个点(编号 1∼n2),二分图共包含 m 条边. 数据保证任意一条边的两个端点都不可能在同一 ...

  9. AcWing 861 二分图的最大匹配

    题目描述: 给定一个二分图,其中左半部包含n1个点(编号1~n1),右半部包含n2个点(编号1~n2),二分图共包含m条边. 数据保证任意一条边的两个端点都不可能在同一部分中. 请你求出二分图的最大匹 ...

最新文章

  1. LINUX下用CTRL+R快速搜索HISTORY历史命令,快速索引到之前使用过的命令行语句
  2. Ubuntu18.04 + Nvida GTX 1660ti显卡 驱动安装
  3. MES系统模块设计之物料控制 Material Control -- 1
  4. 一文弄懂什么是RPC
  5. 2018年android手机版本统计,安兔兔发布2018年12月Android手机性能排行榜
  6. Servlet--ServletInputStream类,ServletOutputStream类
  7. BZOJ4764弹飞大爷——LCT
  8. 计算机在食品科学中的应用统计学,响应面法及其在食品中的应用
  9. 三调业务摘要201709
  10. 王鉴老师--沪师经纪-刘建
  11. 3.7V锂电池升压5V方案
  12. 外贸软件供应链中供应商管理解决方案
  13. vs下qt混合编译错误:MOC问题
  14. 配置postfix邮件监控
  15. 基于android的学生考勤请假app
  16. 最新的JavaScript知识总结,欢迎各位大佬指正,需要的留下邮箱,给你们发原稿(PDF版)...
  17. AD使用技巧——如何改变布线走线的角度
  18. UEFI Boot Flow 系列之 SEC Phase
  19. 【Keras+计算机视觉+Tensorflow】OCR文字识别实战(附源码和数据集 超详细必看)
  20. Matomo API 官方接口详情

热门文章

  1. MRT(MODIS Reprojection Tool) 提取数据
  2. C语言 | C51实现NRF905收发设计(完整源代码)
  3. php 如何实现无状态化,服务无状态化设计分析
  4. 简析.NET Core 以及与 .NET Framework的关系
  5. 数学之路(2)-数据分析-R基础(5)
  6. 【NLP】darmatch: 一个非常高效的多模式字符串匹配工具
  7. 【学术相关】11 个好用的科研工具推荐!工作效率提升 max!
  8. 【深度学习】你不知道的车牌识别系统
  9. 【深度学习】一文搞定面试中的优化算法
  10. 【机器学习基础】Python机器学习的神器- Scikit-learn使用说明