• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

  • 联系
  • 订阅
  • 管理

View Post

poj The Perfect Stall 1274 最大二分匹配

      赤裸裸的最大二分匹配入,直接套匈牙利算法模板

 

#include<iostream>
using namespace std;

const int MAX = 300;

bool arcs[MAX][MAX];
bool isvisit[MAX];
int match[MAX];
int n, m;

bool find(int u)
{
	for (int i = 1; i <= m; i++)
		if (arcs[u][i] && !isvisit[i])
		{
			isvisit[i] = true;
			if (!match[i] || find(match[i]))
			{
				match[i] = u;
				return true;
			}
		}

	return false;
}

int main()
{
	int k;
	int num;

	while (cin >> n >> m)
	{
		memset(arcs, false, sizeof(arcs));
		memset(match, 0, sizeof(match));
		for (int i = 1; i <= n; i++)
		{
			cin >> k;
			for (int j = 0; j < k; j++)
			{
				cin >> num;
				arcs[i][num] = true;
			}
		}
		
		int ans = 0;
		for (int i = 1; i <= n; i++)
		{
			memset(isvisit, false, sizeof(isvisit));
			if (find(i))
				ans++;
		}

		cout << ans << endl;
	}
	return 0;
}

posted on 2011-01-29 20:44  sysuwhj  阅读(173)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3