题目大意

一般图最大匹配.

题解:

求解一般图最大匹配.

直接使用带花树即可.

(带花树也是刚学)...

马上写带花树的ppt,会很通俗易懂.

(充分证明了本苣智商不够,写不出高深的课件)

如果有想要的依然可以直接私信我 QAQ

带花树模板

#include <cstdio>
#include <cstring>
#include <algorithm>
typedef long long ll;
inline void read(int &x){
x=0;char ch;bool flag = false;
while(ch=getchar(),ch<'!');if(ch == '-') ch=getchar(),flag = true;
while(x=10*x+ch-'0',ch=getchar(),ch>'!');if(flag) x=-x;
}
#define rg register int
#define rep(i,a,b) for(rg i=(a);i<=(b);++i)
#define per(i,a,b) for(rg i=(a);i>=(b);--i)
const int maxn = 256;
int n;
bool map[maxn][maxn],inq[maxn],inBlo[maxn],mark[maxn];
int link[maxn],fa[maxn],belong[maxn],q[maxn],l,r;
inline void bloom(int x,int y){
rep(i,0,n) mark[i] = inBlo[i] = false;
#define nx(x) fa[link[(x)]]
int lca;
for(rg i=x;i;i=nx(i)) mark[i = belong[i]] = true;
for(rg i=y;i;i=nx(i)){
i = belong[i];
if(mark[i]){lca = i;break;}
}
for(rg i=x;belong[i] != lca;i=nx(i)){
if(belong[nx(i)] != lca) fa[nx(i)] = link[i];
inBlo[belong[i]] = inBlo[belong[link[i]]] = true;
}
for(rg i=y;belong[i] != lca;i=nx(i)){
if(belong[nx(i)] != lca) fa[nx(i)] = link[i];
inBlo[belong[i]] = inBlo[belong[link[i]]] = true;
}
#undef nx
if(belong[x] != lca) fa[x] = y;
if(belong[y] != lca) fa[y] = x;
rep(i,1,n) if(inBlo[belong[i]]){
belong[i] = lca;
if(!inq[i]) inq[q[++r] = i] = true;
}
}
inline void modify(int s){
int x,y,z = s;
while(z){
y = fa[z];x = link[y];
link[y] = z;link[z] = y;
z = x;
}
}
inline void bfs(int s){
rep(i,0,n){
fa[i] = inq[i] = 0;
belong[i] = i;
}
l = 0;r = -1;q[++r] = s;
inq[s] = true;
while(l <= r){
int u = q[l++];
rep(v,1,n){
if(map[u][v] == 0 || belong[u] == belong[v] || link[u] == v) continue;
if(s == v || link[v] && fa[link[v]]) bloom(u,v);
else if(fa[v] == 0){
fa[v] = u;
if(link[v] != 0){
q[++r] = link[v];
inq[link[v]] = true;
}else{
modify(v);
return ;
}
}
}
}return ;
}
int main(){
read(n);int u,v;
while(scanf("%d%d",&u,&v) != EOF){
map[u][v] = map[v][u] = true;
}
rep(i,1,n) if(link[i] == 0) bfs(i);
int ans = 0;
rep(i,1,n) if(link[i] != 0) ++ ans;
printf("%d\n",ans);
rep(i,1,n){
if(link[i] > i) printf("%d %d\n",i,link[i]);
}
return 0;
}

[Ural1099]工作安排 带花树的更多相关文章

  1. URAL1099 Work Scheduling —— 一般图匹配带花树

    题目链接:https://vjudge.net/problem/URAL-1099 1099. Work Scheduling Time limit: 0.5 secondMemory limit: ...

  2. URAL1099. Work Scheduling(一般图匹配带花树开花算法)

    1099. Work Scheduling Time limit: 0.5 second Memory limit: 64 MB There is certain amount of night gu ...

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

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

  4. kuangbin带你飞 匹配问题 二分匹配 + 二分图多重匹配 + 二分图最大权匹配 + 一般图匹配带花树

    二分匹配:二分图的一些性质 二分图又称作二部图,是图论中的一种特殊模型. 设G=(V,E)是一个无向图,如果顶点V可分割为两个互不相交的子集(A,B),并且图中的每条边(i,j)所关联的两个顶点i和j ...

  5. URAL 1099. Work Scheduling (一般图匹配带花树)

    1099. Work Scheduling Time limit: 0.5 secondMemory limit: 64 MB There is certain amount of night gua ...

  6. 【BZOJ】【2245】【SDOI2011】工作安排

    网络流/费用流 裸题吧……直接建模就好了……所谓的“分段函数”就是吓唬你的,其实就是对于每个人分开建几条流量不同.费用不同的弧而已. 对每种产品,连S->i ,(c[i],0):对每个工作人员 ...

  7. lemon OA 下阶段工作安排

    lemon OA 下阶段工作安排 经验总结 lemon OA系统作为一个中型的java web系统,在架构上还是有着很好地可学习的地方.但是由于经验不足,过程比较迂回.如果真的有经验的话,应该可以做到 ...

  8. BZOJ1572: [Usaco2009 Open]工作安排Job

    1572: [Usaco2009 Open]工作安排Job Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 775  Solved: 337[Submit ...

  9. bzoj 2245 [SDOI2011]工作安排(最小费用最大流)

    2245: [SDOI2011]工作安排 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 1197  Solved: 580[Submit][Statu ...

随机推荐

  1. EhCache 集群 配置(RMI方式)

    这里先说明下环境:JDK1.6.ehcache-core-2.1.0.jar.Tomcat6.Spring3.0.2.使用的是RMI方式配置集群的,这里先吐槽下遇到的情况,在搜相关知识的时候发现到处都 ...

  2. cocos2d-x3.6 生成带类图的离线文档

    我的博客:http://blog.csdn.net/dawn_moon cocos2d-x的官网有点慢,并且最新3.6的在线API文档居然没有了类图,不知道什么原因,之前2.2.6都是有的. 只是能够 ...

  3. bug-2——tab中beforeActivate:在对象活动前触发

    $j("#tabs").tabs({ beforeActivate:function(event,ui){ var ret = apoCheck('${requestScope.a ...

  4. Maven下载、安装和配置(转发:http://blog.csdn.net/jiuqiyuliang/article/details/45390313)

    准备工作 java开发环境(JDK) maven下载地址:http://maven.apache.org/release-notes-all.html 安装 安装maven超级简单,总共分四步: 下载 ...

  5. 用cocos2d-html5做的消除类游戏《英雄爱消除》(3)——游戏主界面

    游戏主界面,同时也是主程序,包括sprite的生成加入以及游戏状态的控制. 下面同样贴下源码再讲解; /** * Power by html5中文网(html5china.com) * author: ...

  6. PHP保存数组到文件中的方法

    ThinkPHP自3.1以后的版本,F函数保存数组时先序列化后再保存到文件中,因为我需要使用C方法来读取自定义配置文件,故需要把PHP数组保存到文件中以便C方法读取,PHP保存数组到文件的方法如下: ...

  7. var妙用

    var广泛使用其实也有用的.比如在一些不太确定类型的地方 (比如要区分int/uint/long/double的时候),用泛型太牛刀而不用又觉得不灵活的时候,其实是比较推荐var的比如设计某种类的时候 ...

  8. linux操作系统使用中的一些总结

    VIM常用命令 gg   //到第一行 (N)G   //到第n行(N为整数) G    //到最后一行 0    //到行头 $  //到行尾 (N)dd  //删除N行,并将内容保存到粘贴板 p ...

  9. opencv学习之路【四】——opencv文件结构介绍

    这里要感谢这篇博主的文章 部分内容转载自此 opencv在2.3版本之前 都是用的c语言实现的 而在2.3以后的版本 做了很多重大的改变 其中最主要的是用c++重写大部分结构 然后文件的结构和2.0之 ...

  10. mono上运行程序常见问题

    1. System.BadImageFormatException: Invalid method header local vars signature token 0x 65d5b2File na ...