洛谷 P2319 [HNOI2006] 超级英雄(匈牙利算法)

题目传送门

解题思路

将题目和锦囊妙计建边,然后对于每一个问题,都跑一次匈牙利,如果当前问题找不到与之配对的锦囊妙计,那么直接停止(因为题目说了答不出就不能往下答了)。

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int n,m,ans;
vector<int> e[100001];
int vis[100001],last[100001];
int an[100001];
bool dfs(int x,int k)
{
	if(vis[x]==k)
		return 0;
	vis[x]=k;
	for(auto y:e[x])
	{
		if(last[y]==0||dfs(last[y],k))
		{
			last[y]=x;
			an[x]=y;
			return 1;
		}
	}
	return 0;
}
int main()
{
	cin>>n>>m;
	int x,y;
	for(int i=1;i<=m;i++)
	{
		scanf("%d%d",&x,&y);
		x++,y++;
		e[i].push_back(x);
		e[i].push_back(y);
	}
	int ti=0;
	for(int i=1;i<=m;i++)
	{
		ti++;
		if(dfs(i,ti))ans++;
		else break;
	}
	cout<<ans<<endl;
	for(int i=1;i<=m;i++)
		if(an[i])
			cout<<an[i]-1<<endl;
}
相关推荐
Ciderw9 分钟前
LLVM编译器简介
c++·golang·编译·编译器·gcc·llvm·基础设施
和光同尘@21 分钟前
74. 搜索二维矩阵(LeetCode 热题 100)
数据结构·c++·线性代数·算法·leetcode·职场和发展·矩阵
一去不复返的通信er22 分钟前
SVD预编码
算法·信息与通信·预编码算法·通信原理
无人等人24 分钟前
CyberRT(apollo) IPC(shm)通信包重复/丢包 bug 及解决方案
c++·bug
Flower#25 分钟前
【模板】图论 最短路 (Floyd+SPFA+Dijkstra)
c++·图论
柠石榴1 小时前
【练习】【二分】力扣热题100 34. 在排序数组中查找元素的第一个和最后一个位置
c++·算法·leetcode·二分
CoderCodingNo1 小时前
【GESP】C++二级真题 luogu-b3865, [GESP202309 二级] 小杨的 X 字矩阵
java·c++
Tisfy1 小时前
LeetCode 2209.用地毯覆盖后的最少白色砖块:记忆化搜索之——深度优先搜索(DFS)
算法·leetcode·深度优先·dfs·题解·记忆化搜索·深度优先搜索
Trouvaille ~1 小时前
【C++篇】树影摇曳,旋转无声:探寻AVL树的平衡之道
数据结构·c++·算法·蓝桥杯·计算机科学·平衡二叉树·avl
EPSDA2 小时前
Linux线程池
linux·运维·服务器·开发语言·c++