[洛谷]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~

相关推荐
普马萨特2 分钟前
Uber H3:地理网格索引在空间数据分析中的应用
数据结构·算法
alphaTao7 分钟前
LeetCode 每日一题 2026/5/11-2026/5/17
算法·leetcode
洛水水7 分钟前
【力扣100题】45.零钱兑换
算法·leetcode·职场和发展
Aaron158838 分钟前
全频段 SDR干扰源模块解决方案(星链干扰、LORA无人机干扰)
人工智能·算法·fpga开发·硬件架构·硬件工程·无人机·信息与通信
AI科技星42 分钟前
全域数学·球面拓扑微扰标准系数η=0.01 应用详解(典籍正式版)
人工智能·算法·数学建模·数据挖掘·机器人
逻辑君1 小时前
物理学研究报告【20260001】
人工智能·算法
AI科技星1 小时前
算法联盟·全域数学公理体系下黑洞标量毛发与LVK引力波O4全维理论、求导、证明、计算、验证、分析
人工智能·线性代数·算法·架构·学习方法·量子计算
谙弆悕博士1 小时前
【附C语言源码】C语言 栈结构 实现及其扩展操作
c语言·开发语言·数据结构·算法·链表·指针·
YuanDaima20481 小时前
图论基础原理与题目说明
数据结构·人工智能·python·算法·图论·手撕代码
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题 第53题】【JVM篇】第13题:JVM采用什么算法判断一个对象是否需要被回收?
java·jvm·算法·面试