10566 Bimatching

  • 题意:一个男生必须跟两个女生匹配,求最大匹配

  • 思路:一般的二分图匹配做不了,网络流也不会建图,这题采用的是一般图匹配

  • 首先在原来二分图的基础上,将一个男生拆成两个点

  • 两个点之间有一条边,这样图至少会有n个匹配

  • 如果想要答案加1,只有当这两个点跟两个女生匹配的时候

  • 所以最后的答案是一般图最大匹配减去n

  • 一般图最大匹配用带花树

#pragma GCC optimize(3, "Ofast", "inline")

#include<bits/stdc++.h>

using namespace std;
const int maxn = 305;
const int maxm = 50050; struct bloosom {
struct edge {
int to, next;
} e[maxm];
int tot = 0, head[maxn]; inline void add(int u, int v) {
++tot;
e[tot].to = v, e[tot].next = head[u], head[u] = tot;
++tot;
e[tot].to = u, e[tot].next = head[v], head[v] = tot;
} int fa[maxn], tag = 0, pre[maxn], match[maxn], q[maxn], r, fl[maxn];
int vis[maxn], all; int findx(int x) {
if (fa[x] == x)return x;
return fa[x] = findx(fa[x]);
} int lca(int u, int v) {
++tag;
u = findx(u);
v = findx(v);
for (;; swap(u, v)) {
if (u) {
if (fl[u] == tag)return u;
fl[u] = tag;
u = findx(pre[match[u]]);
}
}
} void blo(int u, int v, int l) {
for (; findx(u) != l; v = match[u], u = pre[v]) {
pre[u] = v;
if (vis[match[u]] == 1)vis[q[++r] = match[u]] = 0;
if (findx(u) == u) fa[u] = l;
if (findx(match[u]) == match[u]) fa[match[u]] = l;
}
} bool aug(int s) {
for (int j = 1; j <= all; ++j) {
fa[j] = j;
vis[j] = -1;
}
vis[q[r = 1] = s] = 0;
int x, y;
for (int i = 1; i <= r; ++i) {
for (int j = head[x = q[i]]; j; j = e[j].next) {
if (vis[y = e[j].to] == -1) {
pre[y] = x;
vis[y] = 1;
if (!match[y]) {
for (int u = x, v = y, t; u; v = t, u = pre[v]) {
t = match[u];
match[u] = v;
match[v] = u;
}
return 1;
}
vis[q[++r] = match[y]] = 0;
} else if (!vis[y] && findx(x) != findx(y)) {
int l = lca(x, y);
blo(x, y, l);
blo(y, x, l);
}
}
}
return 0;
} inline void init() {
for (int i = 0; i <= all; ++i) {
pre[i] = match[i] = head[i] = 0;
}
tot = 0;
} int solve() {
int ans = 0;
for (int i = 1; i <= all; ++i) {
if (!match[i]) {
if (aug(i)) ans++;
}
}
return ans;
}
} st; int main() {
int _;
scanf("%d", &_);
while (_--) {
int n, m, s;
scanf("%d%d", &n, &m);
st.all = n * 2 + m;
st.init(); for (int i = 1; i <= n; ++i) {
st.add(i, i + n);
for (int j = 1; j <= m; ++j) {
scanf("%1d", &s);
if (s) {
st.add(i, j + (n << 1));
st.add(i + n, j + (n << 1));
}
}
}
printf("%d\n", st.solve() - n);
}
return 0;
}

[一般图最大匹配]Bimatching的更多相关文章

  1. UOJ79 一般图最大匹配

    题目描述 从前一个和谐的班级,所有人都是搞OI的.有 nn 个是男生,有 00 个是女生.男生编号分别为 1,-,n1,-,n. 现在老师想把他们分成若干个两人小组写动态仙人掌,一个人负责搬砖另一个人 ...

  2. [转]带花树,Edmonds's matching algorithm,一般图最大匹配

    看了两篇博客,觉得写得不错,便收藏之.. 首先是第一篇,转自某Final牛 带花树……其实这个算法很容易理解,但是实现起来非常奇葩(至少对我而言). 除了wiki和amber的程序我找到的资料看着都不 ...

  3. HDOJ 4687 Boke and Tsukkomi 一般图最大匹配带花树+暴力

    一般图最大匹配带花树+暴力: 先算最大匹配 C1 在枚举每一条边,去掉和这条边两个端点有关的边.....再跑Edmonds得到匹配C2 假设C2+2==C1则这条边再某个最大匹配中 Boke and ...

  4. 【Learning】带花树——一般图最大匹配

    一般图最大匹配--带花树 问题 ​ 给定一个图,求该图的最大匹配.即找到最多的边,使得每个点至多属于一条边. ​ 这个问题的退化版本就是二分图最大匹配. ​ 由于二分图中不存在奇环,偶环对最大匹配并无 ...

  5. HDU 4687 Boke and Tsukkomi (一般图最大匹配)【带花树】

    <题目链接> 题目大意: 给你n个点和m条边,每条边代表两点具有匹配关系,问你有多少对匹配是冗余的. 解题分析: 所谓不冗余,自然就是这对匹配关系处于最大匹配中,即该匹配关系有意义.那怎样 ...

  6. 【UOJ#79】一般图最大匹配(带花树)

    [UOJ#79]一般图最大匹配(带花树) 题面 UOJ 题解 带花树模板题 关于带花树的详细内容 #include<iostream> #include<cstdio> #in ...

  7. ZOJ 3316 Game 一般图最大匹配带花树

    一般图最大匹配带花树: 建图后,计算最大匹配数. 假设有一个联通块不是完美匹配,先手就能够走那个没被匹配到的点.后手不论怎么走,都必定走到一个被匹配的点上.先手就能够顺着这个交错路走下去,最后一定是后 ...

  8. [WC2016]挑战NPC(一般图最大匹配)

    [WC2016]挑战NPC(一般图最大匹配) Luogu 题解时间 思路十分有趣. 考虑一个筐只有不多于一个球才有1的贡献代表什么. 很明显等效于有至少两个位置没有被匹配时有1的贡献. 进而可以构造如 ...

  9. 【learning】一般图最大匹配——带花树

    问题描述 ​ 对于一个图\(G(V,E)\),当点对集\(S\)满足任意\((u,v)\in S\),均有\(u,v\in V,(u,v)\in E\),且\(S\)中没有点重复出现,我们称\(S\) ...

随机推荐

  1. 小明有5本新书,要借给A、B、C三位小朋友 若每人每次只能借一本,则可以有多少种不同的借法?

    /* 问题描述: 小明有5本新书,要借给A.B.C三位小朋友, 若每人每次只能借一本,则可以有多少种不同的借法? 问题分析: 本题属于数学当中最常见的排列组合问题, 即求从5个数当中取3个不同数的排列 ...

  2. UVALive 3634 数据结构模拟

    这题真是坑啊,题意不明,其实就是往桟里面压入空的set集合,所以之前的询问大小都是只有0,只有add的时候,才会产生新的占空间的集合 用stack和set直接进行模拟 #include <ios ...

  3. selumium 中 xpath获取文本、属性正确写法

    报错“The result of the xpath expression is: [object Attr]. It should be an element” yutube爬虫动态加载,需要用到s ...

  4. Android进阶——多线程系列之Thread、Runnable、Callable、Future、FutureTask

    多线程一直是初学者最抵触的东西,如果你想进阶的话,那必须闯过这道难关,特别是多线程中Thread.Runnable.Callable.Future.FutureTask这几个类往往是初学者容易搞混的. ...

  5. SpringBoot+Shiro (一)

    从网上搜索SpringBoot+Shiro相关文章,大部分都需要DB和Ecache的支持.这里提供一个最简单的Spring+Shiro的配置. 前言: 1. 由于SpringBoot官方已经不再建议使 ...

  6. FZU_1683 矩阵快速幂 求和

    这个题目确实是很简单的一个矩阵快速幂,但是我在求和的时候,用的是标准的求和,即,一共计算logN次Ak,但是这样会超时. 后来就发现原来本身和Sn=Sn-1+Fn:即Sn本身可以写在矩阵当中,所以直接 ...

  7. python画图嵌入html

    #-*- coding=utf-8 -*- import matplotlib import matplotlib.pyplot as plt from io import BytesIO impor ...

  8. 注册网站 captcha reCHAPTCHA 错误

    原因 出现这个错误,是因为注册和提交时候,没有正确输出验证码导致的.网站可能会为了防止恶意注册,而使用验证码.如果验证码没有被正确加载或验证,就会出现相关错误. 解决方案 如果是访问类似kaggle, ...

  9. Linux-线程常见函数

    1.线程创建与回收 (1).pthread_create 主线程用来创造子线程 (2).pthread_join 主线程用来等待(阻塞)回收子线程 (3).pthread_detach   主线程用来 ...

  10. Spring Cloud Zuul 网关服务的fallback

    当我们的zuul进行路由分发时,如果后端服务没有启动,或者调用超时,这时候我们希望Zuul提供一种降级功能,而不是将异常暴露出来. Spring cloud zuul提供这种降级功能,操作步骤如下: ...