【图论02】二分图 1001 过山车
来源:互联网 发布:java web 图片上传 编辑:程序博客网 时间:2024/05/22 07:51
算法思路:二分图。
简单的二分图求最大匹配的模板题,匈牙利算法。任意选择一个点做为起点开始遍历,如果找到“增广路”,则sum++(sum初始化为0)。对所有的点尝试过一次找“增广路”之后(共做了N次),输出sum即为所求。
//模板开始#include <string> #include <vector> #include <algorithm> #include <iostream> #include <sstream> #include <fstream> #include <map> #include <set> #include <cstdio> #include <cmath> #include <cstdlib> #include <ctime>#include <iomanip>#include <string.h>#include <queue>#define SZ(x) (int(x.size()))using namespace std;int toInt(string s){istringstream sin(s); int t; sin>>t; return t;}template<class T> string toString(T x){ostringstream sout; sout<<x; return sout.str();}typedef long long int64;int64 toInt64(string s){istringstream sin(s); int64 t; sin>>t;return t;}template<class T> T gcd(T a, T b){ if(a<0) return gcd(-a, b);if(b<0) return gcd(a, -b);return (b == 0)? a : gcd(b, a % b);}//模板结束(通用部分)#define ifs cin#define MAX 1010int juzhen[MAX][MAX];int used[MAX];int mat[MAX];void init(){memset(juzhen, 0, sizeof(juzhen));}int Augment(int s, int n, int x){int i;for(i = s; i <= n; i++){if(!used[i] && juzhen[x][i]){used[i] = 1;if(mat[i] == -1 || Augment(s, n, mat[i])){mat[i] = x;return 1;}}}return 0;}int Hungary(int s, int n){int i, sum = 0;memset(mat, -1, sizeof(mat));for(i = s; i <= n; i++){memset(used, 0, sizeof(used));if(Augment(s, n, i)){sum++;}}return sum;}//【图论02】二分图 1001 过山车int main(){//ifstream ifs("shuju.txt", ios::in);int k, m, n;int a, b;while(ifs>>k && k != 0){ifs>>m>>n;memset(juzhen, 0, sizeof(juzhen));for(int i = 0; i < k; i++){ifs>>a>>b;juzhen[a][m + b] = 1;//juzhen[m + b][a] = 1;}int max_match = Hungary(1, m + n);cout<<max_match<<endl;}return 0;}
- 【图论02】二分图 1001 过山车
- HDOJ2063过山车<<二分图>>
- 过山车(二分图)
- 【过山车】二分图
- hdu 2063过山车-二分图
- 过山车-二分图最大匹配
- HDOJ2061过山车(二分图)
- HDU-2063-过山车 (二分图)
- hdu2063 过山车(二分图)
- hdu2063 过山车【二分图匹配】
- 【hdu 2063 过山车 二分图】
- hdu 2063 过山车【二分图】
- HDU2063--过山车(二分匹配,二分图)
- 【图算法之二分图】HDU2603---过山车
- hdu 2063 过山车(二分图匹配)
- hdu 过山车(二分图的最大匹配)
- HDU2063 过山车(二分图最大匹配)
- hdu 2063 过山车(二分图匹配)
- java web 的bin哪去了? 头脑风暴
- 外链建立没有能再顽固没有化
- MySQL 讨厌哪种类型的查询
- POJ 3345 Bribing FIPA
- hdu 2608 0 or 1
- 【图论02】二分图 1001 过山车
- Android GPS应用:临近警告
- 继承ListActivity实现ListView
- 外链建立任务中的策略准则
- 通过 ANE(Adobe Native Extension) 启动Andriod服务 推送消息(一)
- java String的split方法容易犯的错误
- 几条有助于学习的方法
- ActivityManager框架解析
- 浅析SEO过程中链接策略的重要性