找匹配中的关键边。

做法: 拆掉一条匹配边,然后对边两边的点做一次增广,如果可以增广,那么此边不是关键边,否则是关键边。

详情可以参见:http://www.docin.com/p-109868135.html

代码:

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <string>
#include <queue>
#include <stack>
#include <vector>
#include <map>
#include <set>
#include <functional>
#include <time.h> using namespace std; const int INF = <<;
const int MAXN = ; bool Matrix[MAXN][MAXN];
int n; int mX[MAXN], mY[MAXN], visX[MAXN], visY[MAXN]; bool dfs(int u) {
visX[u] = true;
for (int v = ; v <= n; v++) if (!Matrix[u][v] && !visY[v]) {
visY[v] = true;
if (mY[v]< || dfs(mY[v])) {
mY[v] = u;
mX[u] = v;
return true;
}
}
return false;
} void input() {
memset(Matrix, false, sizeof(Matrix));
int x, y;
while (scanf("%d%d", &x, &y)!=EOF && (x!=||y!=)) {
Matrix[x][y] = true;
}
} void solve() {
int Max;
memset(mX, -, sizeof(mX));
memset(mY, -, sizeof(mY));
for (int i = ; i <= n; i++) {
memset(visX, false, sizeof(visX));
memset(visY, false, sizeof(visY));
if (dfs(i)) Max++;
}
if (Max<n) {
puts("none");
return ;
}
bool flag = true;
int delX, delY;
for (int i = ; i <= n; i++) {
delX = i; delY = mX[i];
mX[delX] = mY[delY] = -;
Matrix[delX][delY] = true;
memset(visX, false, sizeof(visX));
memset(visY, false, sizeof(visY)); if (!dfs(i)) {
printf("%d %d\n", delX, delY);
mX[delX] = delY; mY[delY] = delX;
flag = false;
}
Matrix[delX][delY] = false;
}
if (flag) puts("none");
} int main() {
#ifdef Phantom01
freopen("FZU1202.txt", "r", stdin);
#endif //Phanaom01 while (scanf("%d", &n)!=EOF) {
input();
solve();
puts("");
} return ;
}

FZU 1202

FZU 1202 信与信封问题 二分图匹配的更多相关文章

  1. Codevs 1222 信与信封问题 二分图匹配,匈牙利算法

    题目: http://codevs.cn/problem/1222/ 1222 信与信封问题   时间限制: 1 s   空间限制: 128000 KB   题目等级 : 钻石 Diamond 题解 ...

  2. codevs 1222 信与信封问题(二分图的完美匹配)

    1222 信与信封问题   题目描述 Description John先生晚上写了n封信,并相应地写了n个信封将信装好,准备寄出.但是,第二天John的儿子Small John将这n封信都拿出了信封. ...

  3. 【wikioi】1222 信与信封问题(二分图+特殊的技巧)

    http://wikioi.com/problem/1222/ 一开始我就想到这样构图的,即可能的连边.但是似乎无法判断. 然后想来想去想不出来.. 题解: 同样是二分图,将可能的连边,然后跑一次最大 ...

  4. FZU - 2039 Pets (二分图匹配 2011年全国大学生程序设计邀请赛(福州))

    Description Are you interested in pets? There is a very famous pets shop in the center of the ACM ci ...

  5. WIKIOI 1222信与信封问题

    题目描述 Description John先生晚上写了n封信,并相应地写了n个信封将信装好,准备寄出.但是,第二天John的儿子Small John将这n封信都拿出了信封.不幸的是,Small Joh ...

  6. 信与信封问题(codevs 1222)

    题目描述 Description John先生晚上写了n封信,并相应地写了n个信封将信装好,准备寄出.但是,第二天John的儿子Small John将这n封信都拿出了信封.不幸的是,Small Joh ...

  7. codevs1222 信与信封问题

    1222 信与信封问题  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond     题目描述 Description John先生晚上写了n封信,并相应地写了 ...

  8. UVA 12549 - 二分图匹配

    题意:给定一个Y行X列的网格,网格种有重要位置和障碍物.要求用最少的机器人看守所有重要的位置,每个机器人放在一个格子里,面朝上下左右四个方向之一发出激光直到射到障碍物为止,沿途都是看守范围.机器人不会 ...

  9. POJ 1274 裸二分图匹配

    题意:每头奶牛都只愿意在她们喜欢的那些牛栏中产奶,告诉每头奶牛愿意产奶的牛棚编号,求出最多能分配到的牛栏的数量. 分析:直接二分图匹配: #include<stdio.h> #includ ...

随机推荐

  1. 中文版 ImageNet Classification with Deep Convolutional Neural Networks

    ImageNet Classification with Deep Convolutional Neural Networks 摘要 我们训练了一个大型深度卷积神经网络来将ImageNet LSVRC ...

  2. 一个PHPer如何深入学习ES搜索引擎?

    公司早在一年前就上ES作为后端搜索服务的项目 ,我们PHPer只是负责实现业务接口,es的一些查询,优化技巧由另一组同事(JAVAer)负责,有时,一个需求过来,改动较大时,需要更改查询json语句, ...

  3. javascript中的正则示例

    // 方式一var obj_re = new RegExp("\d+","gi"); //g 全局,i 不区分大小写obj_re.test("fasf ...

  4. php--tp5在查询到的数据中添加新字段

  5. swift where 的作用

    条件限定: 类型限定: 结构化查询模式. 用于结构体.记录字段.

  6. 洛谷P3355 骑士共存问题 二分图_网络流

    Code: #include<cstdio> #include<cstring> #include<queue> #include<vector> #i ...

  7. [agc011e]increasing numbers

    题意: 如果一个十进制非负整数的所有数位从高位到低位是不减的,我们称它为“上升数”,例如1558,11,3,0都是上升数,而10,20170312则不是: 给定整数N,求最小的k使得N能被表示为k个上 ...

  8. ES6 学习3 函数

    1.函数默认参数 在ES5我们给函数定义参数默认值是怎么样? function action(num) { num = num || 200 //当传入num时,num为传入的值 //当没传入参数时, ...

  9. PHP检验代码执行效率—时间统计方法

    <?php class runtime { ; ; function get_microtime() { list($usec,$sec) =explode('',microtime()); r ...

  10. * ? 【a-z】【0-9】通配符 学习

    通配符顾名思义就是通用的匹配信息的符号,比如星号(*)就是代表匹配零个或多个字符,问号(?)是代表匹配单个字符,中括号内加上数字[0-9]代表匹配单个阿拉伯数字的字符,而中括号内加上字母[abc]则是 ...