一开始还真没想到是一般图匹配这种模型(毕竟才会的带花树)

  把每一个盒子拆成3个,每一个可以放置进它的小球分别向这三个点连边,然后这三个点在连成一个三元环,最终答案就是小球数目-匹配数。

  由于是一般图,所以套一个带花树就可以了。

  

  NOTICE:寻找增广路时,应该从球先找起,这样子才保证了每个球有地方放置。

  


 #include<iostream>
#include<cstdio>
#include<algorithm>
#include<vector>
#include<cstdlib>
#include<cmath>
#include<cstring>
using namespace std;
#define maxn 10010
#define llg long long
#define yyj(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
llg n,m,sett,father[maxn],pre[maxn],match[maxn],vis[maxn],id[maxn],dl[maxn*],head,tail,ans,T,totn,e;
llg c[][]; vector<llg> a[maxn]; llg find(llg x){if (father[x]!=x) father[x]=find(father[x]); return father[x];} llg lca(llg x,llg y)
{
sett++;
while (vis[x]!=sett)
{
if (x)
{
x=find(x);
if (vis[x]==sett) return x;
vis[x]=sett;
if (match[x]!=) x=find(pre[match[x]]);
else x=;
} swap(x,y);
}
return x;
} void change(llg x,llg y,llg fa)
{
llg z;
while (find(x)!=fa)
{
pre[x]=y; z=match[x];
if (id[z]==) {id[z]=,dl[++tail]=z;}
if (find(z)==z) father[z]=fa;
if (find(x)==x) father[x]=fa;
y=z; x=pre[y];
}
} bool bfs(llg p)
{
llg x,w,v;
for (llg i=;i<=n;i++) id[i]=-,father[i]=i;
head=,tail=,dl[]=p; id[p]=;
do
{
x=dl[++head],w=a[x].size();
for (llg i=;i<w;i++)
{
v=a[x][i];
if (id[v]==-)
{
pre[v]=x;
id[v]=;
if (!match[v])
{
llg last,t,now=v;
while (now!=)
{
t=pre[now],last=match[t];
match[t]=now; match[now]=t;
now=last;// v=t;
}//把原lai的匹配和非匹配bian取反
return ;
}
id[match[v]]=,dl[++tail]=match[v];
}
else
if (id[v]== && find(v)!=find(x))
{
llg dad=lca(x,v);
change(x,v,dad);
change(v,x,dad);
}
}
}while (head!=tail);
return ; } void link(llg x,llg y) {a[x].push_back(y),a[y].push_back(x);} void init()
{
for (llg i=;i<=n;i++) a[i].clear(),vis[i]=match[i]=pre[i]=father[i]=id[i]=dl[i]=;
//for (llg i=1;i<=n;i++) for (llg j=1;j<=n;j++) c[i][j]=c[j][i]=0;
scanf("%lld%lld%lld",&n,&m,&e);
totn=n;
llg x,y;
for (llg i=;i<=e;i++)
{
scanf("%lld%lld",&x,&y); llg po=m*+x;
link(po,y*-),link(po,y*-),link(po,y*);
//a[x].push_back(y),a[y].push_back(x);
}
n=n+m*;
for (llg i=;i<=m;i++)
{
link(i*-,i*-),link(i*-,i*),link(i*,i*-);
}
} void oupt()
{
cout<<ans-totn<<endl;
for (llg i=;i<=totn;i++)
{
printf("%lld ",(match[*m+i]-)/+);
}
printf("\n");
} int main()
{
//yyj("a");
cin>>T;
while (T--)
{
ans=;
init();
for (llg i=n;i>;i--)
if (!match[i] && bfs(i)) ans++;
oupt();
}
return ;
}

UOJ 171 【WC2016】挑战NPC的更多相关文章

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

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

  2. [UOJ171][WC2016]挑战NPC

    uoj luogu bzoj sol 你可以列一个表格. 一个框子里放球的数量 0 1 2 3 对"半空框子"数量的贡献 1 1 0 0 把一个框子拆三个点.两两之间连边. 会发现 ...

  3. [BZOJ]4405: [wc2016]挑战NPC(带花树)

    带花树模板 #include<cstdio> #include<cstring> #include<algorithm> using namespace std; ...

  4. [bzoj4405][wc2016]挑战NPC

    来自FallDream的博客,未经允许,请勿转载,谢谢. 小N最近在研究NP完全问题,小O看小N研究得热火朝天,便给他出了一道这样的题目: 有n个球,用整数1到n编号.还有m个筐子,用整数1到m编号. ...

  5. BZOJ 4405 [wc2016]挑战NPC 带花树 一般图最大匹配

    https://www.lydsy.com/JudgeOnline/problem.php?id=4405 这道题大概就是考场上想不出来,想出来也调不出来的题. 把每个桶拆成三个互相有边的点,每个球向 ...

  6. [WC2016]挑战NPC

    Sol 这做法我是想不到\(TAT\) 每个筐子拆成三个相互连边 球向三个筐子连边 然后跑一般图最大匹配 这三个筐子间最多有一个匹配 那么显然每个球一定会放在一个筐子里,一定有一个匹配 如果筐子间有匹 ...

  7. bzoj 4405: [wc2016]挑战NPC【带花树】

    把每个筐子拆成3个,分别表示放0/1/2个,然后把这三个点两两连起来,每一个可以放在筐里的球都想这三个点连边. 这样可以发现,放0个球的时候,匹配数为1,放1个球的时候,匹配数为1,放2个球的时候,匹 ...

  8. 「WC2016」挑战NPC

    「WC2016」挑战NPC 解题思路 这个题建图非常厉害,带花树什么的只会口胡根本写不动,所以我写了机房某大佬教我的乱搞. 考虑把一个筐 \(x\) 拆成 \(x1,x2,x3\) 三个点,且这三个点 ...

  9. 【BZOJ4405】【WC2016】挑战NPC(带花树)

    [BZOJ4405][WC2016]挑战NPC(带花树) 题面 BZOJ 洛谷 Uoj Description 小N最近在研究NP完全问题,小O看小N研究得热火朝天,便给他出了一道这样的题目: 有n个 ...

随机推荐

  1. uvloop —— 超级快的 Python 异步网络框架

    简短介绍 asyncio是遵循Python标准库的一个异步 I/O框架.在这篇文章里,我将介绍 uvloop: 可以完整替代asyncio事件循环.uvloop是用Cython写的,基于 libuv. ...

  2. [参考资料] 80个Python经典资料(教程+源码+工具)汇总

    AD : 2018重磅地面课程<机器读心术之语音识别前沿实战特训营>,迈向人工智能新高度 [专题推荐]Python系列英文原版电子书 http://down.51cto.com/zt/10 ...

  3. word转pdf时图片质量下降的解决方案__亲测有效

    写论文时经常需要将word文档转成pdf文档,通常的做法是word另存为pdf文档,这样很简洁很方面,可是最大的问题是图片质量会大大下降.究其原因,“另存为”选项会压缩图片,以降低pdf文档的大小.解 ...

  4. iOS 新浪微博-1.0框架搭建

    项目搭建 1.新建一个微博的项目,去掉屏幕旋转 2.设置屏幕方向-->只有竖向 3.使用代码构建UI,不使用storyboard 4.配置图标AppIcon和LaunchImage 将微博资料的 ...

  5. Lintcode: Kth Prime Number (Original Name: Ugly Number)

    Ugly number is a number that only have factors 3, 5 and 7. Design an algorithm to find the kth numbe ...

  6. VUE滚动条插件——vue-happy-scroll

    最近自己在自学vue2.0,然后就自己摸索做一个简单的后台管理系统,在做的过程中,总感觉不同浏览器自带的滚动条样式不统一,也很难看,所以就在网上找一些使用vue的滚动条插件.最开始用的是Easy-sc ...

  7. C#中DataTable

    .C#中DataTable技术学习 2009-09-10 14:37:18 阅读1496 评论0   字号:大中小 订阅 . 1.在DataTable中执行DataTable.Select(" ...

  8. zw版【转发·台湾nvp系列Delphi例程】HALCON MirrorImage2

    zw版[转发·台湾nvp系列Delphi例程]HALCON MirrorImage2 procedure TForm1.Button1Click(Sender: TObject);var op: HO ...

  9. 安装vscode with springboot

    1.安装jdk8 2.下载vscode,一切按照默认配置完成安装.下载地址:https://code.visualstudio.com 3.安装完成后,运行vscode.如果没有任何反应,在命令行上运 ...

  10. LabVIEW如何方便地调用DLL文件

    转自:http://bbs.elecfans.com/jishu_469502_1_1.html   LabVIEW调用DLL文件 LabVIEW支持通过调用DLL文件的方式与其它编程语言混合使用.比 ...