洛谷 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;
}
相关推荐
坚果派·白晓明7 小时前
【鸿蒙PC】SDL3 适配:AtomCode + Skills 快速集成 NAPI 测试工具
c++·华为·ai编程·harmonyos·atomcode
云絮.7 小时前
数据库操作
数据库·mysql·算法·oracle
小林ixn8 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫8 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
凡人叶枫9 小时前
Effective C++ 条款16:成对使用 new 和 delete 时要采取相同形式
开发语言·c++·effective c++
菜鸟‍9 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展
不吃土豆的马铃薯9 小时前
C++ 高性能网络缓冲区 Buffer 源码解析
linux·服务器·开发语言·网络·c++
.千余10 小时前
【C++】C++继承入门(下):友元、静态成员与菱形继承的底层逻辑
开发语言·c++·笔记·学习·其他
初中就开始混世的大魔王10 小时前
6 Fast DDS-传输层
开发语言·c++·中间件·信息与通信
退休倒计时10 小时前
【每日一题】LeetCode 142. 环形链表 II TypeScript
算法·leetcode·链表·typescript