【bzoj1191】【HNOI2006】【超级英雄】【Hero】【二分图匹配】
2016-08-02 09:14
513 查看
题目大意
给出一些题目,每题有两个锦囊,用其中一个一定能解决一道题,必须按顺序解决题目,求最多可以解决多少道题目。
解题思路
显然用匈牙利做二分图匹配,注意按顺序做,一旦有一个失配就停止并输出答案。
code
#include<set> #include<cmath> #include<cstdio> #include<cstring> #include<algorithm> #define LL long long #define fo(i,j,k) for(int i=j;i<=k;i++) #define fd(i,j,k) for(int i=j;i>=k;i--) using namespace std; int const maxn=1001,maxm=1001; int n,m,to[maxm+10][10],pai[maxn+10]; bool visit[maxn+10]; bool match(int now){ visit[now]=1; fo(i,1,2){ int next=to[now][i]; if((!pai[next])||((!visit[pai[next]])&&(to[pai[next]][0])&&(match(pai[next])))){ pai[next]=now; return 1; } } return 0; } int main(){ freopen("d.in","r",stdin); freopen("d.out","w",stdout); scanf("%d%d",&n,&m); int ans=0; fo(i,1,m){ scanf("%d%d",&to[i][1],&to[i][2]);to[i][0]=1; if(match(i))ans++; else break; memset(visit,0,sizeof(visit)); } printf("%d",ans); return 0; }
相关文章推荐
- poj 1039(计算几何)
- 树的直径(最长路) 的详细证明
- 理解PHP中变量的作用域
- Android_Intent_data_type
- 两阶段提交及JTA
- hdoj 1004 学习思路
- Android开发中如何保证activity的生命活性!
- poj 2516 Minimum Cost(k次最小费用最大流)
- 剑指Offer:替换空格
- 观察者模式Observer
- 合并压缩技术
- 前言
- jquery的layer弹出层框架,如果设置 iframe弹出一个页面里是表单提交,提交完怎么关闭弹出层
- nyoj 27 水池数目【DFS】
- ArcGIS Engine开发之旅01---产品组成、逻辑体系结构
- zabbix监控linux 以及监控mysql
- poj 1113(凸包)
- Cocos2d-JS 3.12版本Windows环境配置
- 【代码笔记】服务器检查浏览器是否关闭
- AngularJS基础 ng-init 指令简单示例