bzoj 2744 [HEOI2012]朋友圈——补图!+匈牙利算法
题目: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]朋友圈——补图!+匈牙利算法的更多相关文章
- bzoj 2744: [HEOI2012]朋友圈 二分图匹配
2744: [HEOI2012]朋友圈 Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 612 Solved: 174[Submit][Status] ...
- 【刷题】BZOJ 2744 [HEOI2012]朋友圈
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- bzoj 2744: [HEOI2012]朋友圈
#include<cstdio> #include<iostream> #define M 3010 using namespace std; ],u[M*M>>] ...
- 【BZOJ 2744】 2744: [HEOI2012]朋友圈 (最大团,二分图匹配,构图)
2744: [HEOI2012]朋友圈 Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他 ...
- 【BZOJ 2744 】[HEOI2012]朋友圈
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- 【二分图】HEOI2012 朋友圈
题目内容 洛谷链接 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大 ...
- BZOJ2744:[HEOI2012]朋友圈(最大团,乱搞)
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- luogu P2423 [HEOI2012]朋友圈 (最大团)
在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目.两个国家看成是 ...
- BZOJ 3168 Heoi2013 钙铁锌硒维生素 矩阵求逆+匈牙利算法
题目大意:给定一个n∗n的满秩矩阵A和一个n∗n的矩阵B.求一个字典序最小的1...n的排列a满足将随意一个Ai换成Bai后矩阵A仍然满秩 我们考虑建立一个二分图.假设Ai能换成Bj.就在i−> ...
随机推荐
- STM32 USB虚拟串口
串口调试在项目中被使用越来越多,串口资源的紧缺也变的尤为突出.很多本本人群,更是深有体会,不准备一个USB转串口工具就没办法进行开发.本章节来简单概述STM32低端芯片上的USB虚拟串口的移植.在官方 ...
- 【Head First Servlets and JSP】笔记13:session & cookie
session的接口 杀死会话 cookie的性质 cookie的接口 再总结——cookie.session.JSESSIONID的前世今生 简单的定制cookie示例 1.session的接口,配 ...
- python异步库
https://github.com/aio-libs 异步库
- win7 与 Ubuntu 16.04 文件传送
win7 与 Ubuntu 16.04 文件传送 环境:主机系统为win7,虚拟机为vmware12, 虚拟系统为ubuntu 16.04 方案一: 通过虚拟机vmware的共享文件夹实现. 方案二: ...
- 【简单dp】poj 1458 最长公共子序列【O(n^2)】【模板】
最长公共子序列可以用在下面的问题时:给你一个字符串,请问最少还需要添加多少个字符就可以让它编程一个回文串? 解法:ans=strlen(原串)-LCS(原串,反串); Sample Input abc ...
- codeforces 435B
题意:只能对相邻的两个数字进行交换,允许k次交换,输出交换能得到的最大的数.从最高位开始寻找最优,每次寻找能交换的步数里交换到的最大值进行交换. #include<cstdio> #inc ...
- php-fpm docker 容器 搭建
继续上一篇文章(centos 7 容器的搭建) 下面构建一个php-fpm镜像: dockerfile 文件如下: # # MAINTAINER # DOCKER-VERSION # # Docker ...
- DataX-ElasticSearch(写)
DataX写入ElasticSearch 1 快速介绍 数据导入elasticsearch的插件 2 实现原理 使用elasticsearch的rest api接口, 批量把从reader读入的数据写 ...
- 直播P2P技术1-技术入门
1. 直播协议 直播协议主要有RTMP,HLS,MPEG-DASH,RTSP,HTTP-FLV等.每种协议都各有长短,比如RTMP延迟低,但诞生于Adobe,依赖于Flash Player,在如今FL ...
- Ubuntu 没有mkinitrd 解决方法
1. 先apt-get install 先装cramfsprogs 2. http://archive.debian.net/zh-cn/sarge/initrd-tools 下载initrd-to ...