洛谷 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;
}
相关推荐
Chrikk2 分钟前
【下篇】C++20 约束、NCCL 通信与并发模型
c++·c++20·c++40周年
MC皮蛋侠客2 分钟前
C++17多线程编程全面指南
开发语言·c++
獭.獭.4 分钟前
C++ -- STL【vector的使用】
c++·stl·vector
郝学胜-神的一滴7 分钟前
Linux C++系统编程:使用mmap创建匿名映射区
linux·服务器·开发语言·c++·程序人生
李余博睿(新疆)11 分钟前
双向指针算法(练习)
c++
慕沐.13 分钟前
【算法】冒泡排序的原理及实现
java·算法·排序算法
TracyCoder12314 分钟前
分布式算法(八):一致性哈希——分布式系统的负载均衡利器
分布式·算法·哈希算法
新手村领路人14 分钟前
c++ opencv缺少openh264-1.8.0-win64.dll
开发语言·c++
kyle~15 分钟前
C++ --- noexcept关键字 明确函数不抛出任何异常
java·开发语言·c++
lijiatu1008617 分钟前
[C++ ]qt槽函数及其线程机制
c++·qt