题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2744

求最大的团<==>补图(有边的变成没边、没边的变成有边)的最大独立集!

A国的奇数和偶数变成两个团,B国变成一个二分图,A国和B国之间还有一些任意的边。

B国的部分肯定是求最大独立集。A国呢?A、B国的选点会互相影响。

其实枚举A国的选点情况就行了!每次把相关的B国点删掉,跑匈牙利。

观察数据范围,还专门分成两部分,一看就是一些复杂度在A国点上、一些复杂度在B国点上嘛!

思路。要敢于想补图。要能想到一些稍微暴力一点的方法,如枚举,而不是钻研如何权衡A国B国的选点情况什么的(==要回算时间复杂度)。

1A还是极好的。

时间复杂度玄学。不过匈牙利原来是边越多跑得越快呀。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=,M=;
int T,n,m,c,pos[N],cos[M],b[M],hd[N],xnt,p0,p1,c0,c1,ans,cnt,per[M];
bool bf[M][M],af[N][M],qx[M],vis[M];
struct Ed{
int nxt,to;Ed(int n=,int t=):nxt(n),to(t) {}
}ed[N*M];
void add(int x,int y)
{
ed[++xnt]=Ed(hd[x],y);hd[x]=xnt;
}
bool check(int i,int j)
{
int k=(b[i]|b[j]),ct=;
while(k)k-=(k&-k),ct++;
return ct&;
}
bool dfs(int a)
{
for(int i=c1;i<=m;i++)
if(bf[a][i]&&!qx[i]&&!vis[i])
{
vis[i]=;
if(!per[i]||dfs(per[i]))
{
per[i]=a;return true;
}
}
return false;
}
int xyl()
{
int ret=;memset(per,,sizeof per);
for(int i=;i<=c0;i++)
if(!qx[i]){
memset(vis,,sizeof vis);
if(dfs(i))ret++;
}
return ret;
}
void solve()
{
for(int i=;i<=p0;i++)
for(int j=p1;j<=n;j++)
{
memset(qx,,sizeof qx);
for(int k=hd[i];k;k=ed[k].nxt)qx[ed[k].to]=;
for(int k=hd[j];k;k=ed[k].nxt)qx[ed[k].to]=;
cnt=;for(int i=;i<=m;i++)if(!qx[i])cnt++;
cnt-=xyl();ans=max(ans,cnt+);
}
for(int i=;i<=n;i++)
{
memset(qx,,sizeof qx);
for(int k=hd[i];k;k=ed[k].nxt)qx[ed[k].to]=;
cnt=;for(int i=;i<=m;i++)if(!qx[i])cnt++;
cnt-=xyl();ans=max(ans,cnt+);
}
memset(qx,,sizeof qx);cnt=m;
cnt-=xyl();ans=max(ans,cnt);
}
int main()
{
// scanf("%d",&T);
// while(T--)
// {
memset(hd,,sizeof hd);xnt=;ans=;
memset(bf,true,sizeof bf);memset(af,,sizeof af);
scanf("%d%d%d",&n,&m,&c);p0=;p1=n+;int x,y;
for(int i=;i<=n;i++)
{
scanf("%d",&x);
if(x&)pos[i]=++p0;
else pos[i]=--p1;
}
c0=;c1=m+;
for(int i=;i<=m;i++)
{
scanf("%d",&b[i]);
if(b[i]&)cos[i]=++c0;
else cos[i]=--c1;
for(int j=;j<i;j++)
if(check(i,j))bf[cos[i]][cos[j]]=bf[cos[j]][cos[i]]=;
}
while(c--)
{
scanf("%d%d",&x,&y);
af[pos[x]][cos[y]]=;
}
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
if(!af[i][j])add(i,j);
solve();printf("%d\n",ans);
// }
return ;
}

bzoj 2744 [HEOI2012]朋友圈——补图!+匈牙利算法的更多相关文章

  1. bzoj 2744: [HEOI2012]朋友圈 二分图匹配

    2744: [HEOI2012]朋友圈 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 612  Solved: 174[Submit][Status] ...

  2. 【刷题】BZOJ 2744 [HEOI2012]朋友圈

    Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...

  3. bzoj 2744: [HEOI2012]朋友圈

    #include<cstdio> #include<iostream> #define M 3010 using namespace std; ],u[M*M>>] ...

  4. 【BZOJ 2744】 2744: [HEOI2012]朋友圈 (最大团,二分图匹配,构图)

    2744: [HEOI2012]朋友圈 Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他 ...

  5. 【BZOJ 2744 】[HEOI2012]朋友圈

    Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...

  6. 【二分图】HEOI2012 朋友圈

    题目内容 洛谷链接 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大 ...

  7. BZOJ2744:[HEOI2012]朋友圈(最大团,乱搞)

    Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...

  8. luogu P2423 [HEOI2012]朋友圈 (最大团)

    在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目.两个国家看成是 ...

  9. BZOJ 3168 Heoi2013 钙铁锌硒维生素 矩阵求逆+匈牙利算法

    题目大意:给定一个n∗n的满秩矩阵A和一个n∗n的矩阵B.求一个字典序最小的1...n的排列a满足将随意一个Ai换成Bai后矩阵A仍然满秩 我们考虑建立一个二分图.假设Ai能换成Bj.就在i−> ...

随机推荐

  1. 【TopCoder】SRM160 DIV1总结

    做了两道题之后才发现做的是DIV1,不是DIV2,DIV1的第二道题是DIV1的第三道题,果断决定第3题就不看了=.= 250分题:给定一个时间起点8:00 AM DAY 1,再给出一组时间终点,格式 ...

  2. golang注册码

    许可证服务认证 由于更新,最近注册码都不能用了,下面是能用的, http://idea.youbbs.org

  3. 八、golang文本操作、json协议

    一.终端读写 操作终端相关文件语句常量,go所有的都是接口 os.Stdin:标准输入 os.Stdout:标准输入,只要实现输出这个接口,打印到终端, os.Stderr:标准错误输出 os.Ope ...

  4. JavaWeb Cookie

    1. Cookie 1.1. Cookie概述 Cookie译为小型文本文件或小甜饼,Web应用程序利用Cookie在客户端缓存服务器端文件.Cookie是以键值对形式存储在客户端主机硬盘中,由服务器 ...

  5. Request对象介绍(客户端到服务器)

    1.处理请求和响应的过程request,response,关于request可以从三个方面着手学习.1:如何获取请求头  行  体   2:请求中文处理     3:请求对象的其它常用方法 1.1:r ...

  6. sql server deadlock problem

    https://www.red-gate.com/simple-talk/sql/learn-sql-server/how-to-track-down-deadlocks-using-sql-serv ...

  7. Elasticsearch-->Get Started-->Basic concepts

    https://www.elastic.co/guide/en/elasticsearch/reference/current/getting-started-concepts.html There ...

  8. STAR manual

    来源:STARmanual.pdf 来源:Calling variants in RNAseq PART0 准备工作 #STAR 安装前的依赖的工具 #Red Hat, CentOS, Fedora. ...

  9. 文件系统中跳转【TLCL】

    pwd - Print name of current working directory cd - Change directory ls - List directory contents Lin ...

  10. (转)Openstack Cascading和Nova Cell

    Openstack是看着AWS成长起来的,这点毋庸置疑:所以AWS大规模商用已成事实的情况下,Openstack也需要从架构和产品实现上进行优化,以满足大规模商用的要求.从已有的实现来看其中两种方式值 ...