洛谷P3386——二分图匹配

题目:https://www.luogu.org/problemnew/show/P3386

二分图匹配模板,注意左部点只dfs未匹配点。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,m,e,a[1005],b[2005],ct,head[1005],pre[2005],ans;
bool vis[1005],pe[1005];
struct N{
	int to,next;
}edge[300005];
void add(int x,int y)
{
	ct++;
	edge[ct].to=y;
	edge[ct].next=head[x];
	head[x]=ct;
}
bool dfs(int x)
{
	for(int i=head[x];i;i=edge[i].next)
	{
		int u=edge[i].to;
		if(vis[u])continue;
		vis[u]=1;
		if(!pre[u]||dfs(pre[u]))
		{
			pre[u]=x;
			return 1;
		}
	}
	return 0;
}
int main()
{
	scanf("%d%d%d",&n,&m,&e);
	for(int i=1;i<=e;i++)
	{
		int x,y;
		scanf("%d%d",&x,&y);
		if(y>m||x>n)continue;
		add(x,y);
	}
	for(int i=1;i<=n;i++)
	{
		memset(vis,0,sizeof vis);
		if(!pe[i]&&dfs(i))pe[i]=1,ans++;//左部点必须非匹配!
	}
	printf("%d",ans);
	return 0;
}

  

原文地址:https://www.cnblogs.com/Zinn/p/8516234.html

时间: 2024-07-29 01:54:06

洛谷P3386——二分图匹配的相关文章

AC日记——【模板】二分图匹配 洛谷 P3386

题目背景 二分图 题目描述 给定一个二分图,结点个数分别为n,m,边数为e,求二分图最大匹配数 输入输出格式 输入格式: 第一行,n,m,e 第二至e+1行,每行两个正整数u,v,表示u,v有一条连边 输出格式: 共一行,二分图最大匹配 输入输出样例 输入样例#1: 1 1 1 1 1 输出样例#1: 1 说明 n,m<=1000,1<=u<=n,1<=v<=m 因为数据有坑,可能会遇到v>m的情况.请把v>m的数据自觉过滤掉. 算法:二分图匹配 思路: 二分图模

洛谷—— P3386 【模板】二分图匹配

https://www.luogu.org/problem/show?pid=3386 题目背景 二分图 题目描述 给定一个二分图,结点个数分别为n,m,边数为e,求二分图最大匹配数 输入输出格式 输入格式: 第一行,n,m,e 第二至e+1行,每行两个正整数u,v,表示u,v有一条连边 输出格式: 共一行,二分图最大匹配 输入输出样例 输入样例#1: 1 1 1 1 1 输出样例#1: 1 说明 n,m<=1000,1<=u<=n,1<=v<=m 因为数据有坑,可能会遇到v

二分图匹配([洛谷]P3386 模板 二分图匹配)

二分图匹配其实十分简单,原理只有一个,能换则换,腾出这个妹子的位置,不要考虑其他人是不是很不满意从他喜欢中最喜欢的那一个变成了他喜欢中的最不喜欢的那一个,知道了这个原理,n遍DFS就可以过了: #include<stdio.h> #include<string.h> const int Inf=1e9+10,maxn=5010,maxm=5010,maxe=10010; int gi(){ int sum=0,f=1;char ch=getchar(); while(ch>'

【洛谷 p3386】模板-二分图匹配(图论)

题目:给定一个二分图,结点个数分别为n,m,边数为e,求二分图最大匹配数. 解法:匈牙利算法.(以前我总是不记得......)实质上应该有贪心的思想,每次都尽量匹配,找到能和自己匹配的也尽量让它们匹配.若对方已有匹配的对象,就让那个对象尽量调整来使自己这对能凑起来.而要注意,每次问过的对象就不要再问了,也就是不要让它的对象总是换来换去...... 1 #include<cstdio> 2 #include<cstdlib> 3 #include<cstring> 4 #

洛谷P3386 【模板】二分图匹配

匈牙利算法模板 1 /*by SilverN*/ 2 #include<algorithm> 3 #include<iostream> 4 #include<cstring> 5 #include<cstdio> 6 #include<cmath> 7 #include<vector> 8 using namespace std; 9 const int mxn=1010; 10 int read(){ 11 int x=0,f=1;

P3386 【模板】二分图匹配

洛谷—— P3386 [模板]二分图匹配 题目背景 二分图 题目描述 给定一个二分图,结点个数分别为n,m,边数为e,求二分图最大匹配数 输入输出格式 输入格式: 第一行,n,m,e 第二至e+1行,每行两个正整数u,v,表示u,v有一条连边 输出格式: 共一行,二分图最大匹配 输入输出样例 输入样例#1: 1 1 1 1 1 输出样例#1: 1 说明 n,m<=1000,1<=u<=n,1<=v<=m 因为数据有坑,可能会遇到v>m的情况.请把v>m的数据自觉过

二分图匹配——匈牙利算法

日常吐槽:哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈今天是这么久以来唯一一次大爽(?)的日子.我,赵·机智·小机灵鬼儿用十分钟AC了XXX模板!掌声鼓励! 思路照样见XXX博客 https://blog.csdn.net/c20180630/article/details/70175814 反正小机灵鬼儿只是来贴代码的 例题 洛谷P3386 [模板]二分图匹配 题目背景 二分图 题目描述 给定一个二分图,结点个数分别为n,m,边数为e,求二分图最大匹配数 输入输出格式 输入格式: 第一行,n,m,e 第二至

网络流24题 第一题 - 洛谷2756 飞行员配对方案 二分图匹配 匈牙利算法

欢迎访问~原文出处--博客园-zhouzhendong 去博客园看该题解 题目传送门 题意概括 裸的二分图匹配 题解 匈牙利算法 上板子 代码 #include <cstring> #include <cstdio> #include <algorithm> #include <cstdlib> #include <cmath> using namespace std; const int N=100+5; int m,n,a,b,match[N

Dinic二分图匹配 || Luogu P3386

题面:[模板]二分图匹配 思路:Dinic实现二分图匹配,要建一个超级源点(S)和超级汇点(T),分别定为N+M+1和N+M+2 然后S去和N中的数建正边和反边,正边权值为1,反边权值为0:M中的数去与T建正边和反边,正边权值为1. N.M之间的数建图一样. 然后就去跑最大流. 注意:在Dinic函数中每次更新Cur的值时,要把S和T的Cur也更新了. 代码: 1 #include<cstdio> 2 #include<cstring> 3 #include<iostream