[洛谷]P2071 座位安排 (匈牙利算法 - 二分图最大匹配)

1:思路:(匈牙利算法(二分图最大匹配))

一个比较裸的二分图最大匹配。

2:几乎模板,不同的就是建边的问题:(解决方案)

不难发现是把每个人与希望坐的排数建一条边,但是因为一排有两个座位,所以就把每一排的两个座位拆成两个点,分别建边,再求最大匹配即可。

我把第 x 排的两个座位分别设为 x 和 x+i,然后直接向这两个点建边。

3:ACcode:

复制代码
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=8e3+10,M=1e5+10;
int h[N],e[M],ne[M],idx;
bool vis[N];
int res,match[N],n,m,ans[N];
void add(int a,int b) {
	e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}
bool find(int t) {
	for(int i=h[t]; i!=-1; i=ne[i]) {
		int j=e[i];
		if(!vis[j]) {
			vis[j]=true;
			if(match[j]==0||find(match[j])) {
				match[j]=t,ans[t]=j;
				return true;
			}
		}
	}
	return false;
}
void solve() {
	cin>>n;
	memset(h,-1,sizeof h);
	for(int i=1; i<=2*n; i++) {
		int a,b;
		cin>>a>>b;
	    add(a,i),add(a+n,i);//每排两个座位
	    add(b,i),add(b+n,i);
	}
	for(int i=1; i<=2*n; i++) {
		memset(vis,false,sizeof vis);
		if(find(i)) res++;
	}
	cout<<res<<"\n";
}
signed main() {


	ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);
	int tt=1;
	//cin>>tt;
	while(tt--) solve();
	return 0;
}
//3

over~

相关推荐
go546315846514 分钟前
修改Spatial-MLLM项目,使其专注于无人机航拍视频的空间理解
人工智能·算法·机器学习·架构·音视频·无人机
油泼辣子多加31 分钟前
【Torch】nn.BatchNorm1d算法详解
算法
nlog3n32 分钟前
基于 govaluate 的监控系统中,如何设计灵活可扩展的自定义表达式函数体系
算法·go
IT古董44 分钟前
【第三章:神经网络原理详解与Pytorch入门】01.神经网络算法理论详解与实践-(2)神经网络整体结构
pytorch·神经网络·算法
ThetaarSofVenice1 小时前
垃圾收集相关算法Test
java·jvm·算法
小陈phd1 小时前
langchain从入门到精通(二十八)——RAG优化策略(六)集成多种检索器算法实现混合检索及问题转换总结
算法
是小王同学啊~1 小时前
(LangChain)RAG系统链路向量检索器之Retrievers(五)
python·算法·langchain
薰衣草23332 小时前
一天两道力扣(1)
算法·leetcode·职场和发展
一粒沙白猫2 小时前
Java综合练习04
java·开发语言·算法
爱coding的橙子2 小时前
每日算法刷题Day41 6.28:leetcode前缀和2道题,用时1h20min(要加快)
算法·leetcode·职场和发展