洛谷 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;
}
相关推荐
会编程的土豆15 小时前
【数据结构与算法】 二叉树做题
开发语言·数据结构·c++·算法
木禾ali0th15 小时前
告别大模型“裸奔”:开源项目 ClawVault 架构与核心能力解析
算法·安全
Storynone15 小时前
【Day28】LeetCode:509. 斐波那契数,70. 爬楼梯,746. 使用最小花费爬楼梯
python·算法·leetcode
wangjialelele15 小时前
C++11、C++14、C++17、C++20新特性解析(一)
linux·c语言·开发语言·c++·c++20·visual studio
DeepModel15 小时前
【统计检验】方差分析(ANOVA)
算法
sz-lcw15 小时前
HOG特征向量计算方法
人工智能·python·算法
闻缺陷则喜何志丹16 小时前
【博弈论】P8144 [JRKSJ R4] BBWWBB|普及+
c++·算法·洛谷·博弈论
l1t16 小时前
Qwen 3.5plus一步做对的欧拉计划701题
算法·动态规划·欧拉计划
Book思议-16 小时前
【数据结构实战】链表找环入口的经典问题:快慢指针法
c语言·数据结构·算法·链表
tankeven16 小时前
HJ135 计树
c++·算法