【BZOJ 2744 】[HEOI2012]朋友圈
Description
S∈A∪ B ,对于所有的i,j∈ S ,i 和 j 是朋友
由于落后的古代,没有电脑这个也就成了每年最大的难题,而你能帮他们求出最大朋 友圈的人数吗?
Input
Output
Sample Input
1 2
2 6 5 4
1 1
1 2
1 3
2 1
2 2
2 3
2 4
Sample Output
【样例说明】
最大朋友圈包含A国第1、2人和B国第1、2、3人。
HINT
【数据范围】
两类数据
第一类:|A|<=200 |B| <= 200
第二类:|A| <= 10 |B| <= 3000
原来二分图还能这么玩?我觉得这个题还是相当神的。。。果真我很弱
对于A国显然可得奇数和偶数之间有边,对于B国,奇数和奇数之间有边,偶数和偶数之间有边,奇数和偶数之可能有边
根据定义,就是求这张图上的最大团
如何求最大团?据说这是一个相当神的NP问题,可以用搜索解,显然这样不行
对于这个题来说
建立反图
我们可以发现A国的同种数之间构成了一张完全图,B国则构成一张二分图
由某个定理求一个图的最大团等于求一张图反图的最大独立集(我不知道这样说对不对,反正对这个题来说是对的)
因为是最大独立集,A图中的人至多选两个,B图中把反图中和A国相连的边删掉,然后跑最大独立集。
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=;
struct ee{int to,next;}e[N*N];
bool map[N][N],vis[N],visit[N];
int b[N],a[N],a1[N],a2[N],head[N],link[N];
int ans,A,B,M,cnt,n1,n2,T;
void ins(int u,int v){
e[++cnt].to=v,e[cnt].next=head[u],head[u]=cnt;
} bool check(int x){
if (vis[x]) return ;
for (int i=head[x];i;i=e[i].next){
int v=e[i].to;
if (!vis[v]&&!visit[v]){
vis[v]=;
if (!link[v]||check(link[v])){
link[v]=x;
return ;
}
}
}
return ;
} int main(){
{
scanf("%d%d%d",&A,&B,&M);
for (int i=;i<=A;i++) {
scanf("%d",&a[i]);
if (a[i]&==) a1[++n1]=i;else a2[++n2]=i;
}
for (int i=;i<=B;i++) scanf("%d",&b[i]);
memset(map,true,sizeof(map));
int u,v;
for (int i=;i<=M;i++){
scanf("%d%d",&u,&v);
map[u][v]=; map[v][u]=;
}
for (int i=;i<=B;i++)
for (int j=i+;j<=B;j++){
if(i==j) continue;
if (!((b[i]^b[j])&))continue;
else{
int t=;
for (int k=;<<k<=(b[i]|b[j]);k++)
if ((b[i]|b[j])&(<<k)) t++;
if (t%==) ins(i,j),ins(j,i);
}
}
for (int i=;i<=B;i++)map[i][]=,map[][i]=;
for (int i=;i<=n1;i++)
for (int j=;j<=n2;j++){
int t=;
int x=a1[i],y=a2[j];
memset(visit,,sizeof(visit));
memset(link,,sizeof(link));
for (int k=;k<=B;k++)if (map[x][k]||map[y][k]) visit[k]=,t++;
for (int k=;k<=B;k++)
if (b[k]&==&&!visit[k]){
memset(vis,,sizeof(vis));
if (check(k)) t++;
}
if (i) t--;if (j) t--;
ans=max(ans,B-t);
}
printf("%d",ans);
}
}
【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]朋友圈——补图!+匈牙利算法
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2744 求最大的团<==>补图(有边的变成没边.没边的变成有边)的最大独立集! A ...
- bzoj 2744: [HEOI2012]朋友圈
#include<cstdio> #include<iostream> #define M 3010 using namespace std; ],u[M*M>>] ...
- 【BZOJ 2744】 2744: [HEOI2012]朋友圈 (最大团,二分图匹配,构图)
2744: [HEOI2012]朋友圈 Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他 ...
- BZOJ2744:[HEOI2012]朋友圈(最大团,乱搞)
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- luogu P2423 [HEOI2012]朋友圈 (最大团)
在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目.两个国家看成是 ...
- 【二分图】HEOI2012 朋友圈
题目内容 洛谷链接 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大 ...
- BZOJ2744: [HEOI2012]朋友圈
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2744 最大团是一个np问题.. 对于本题,做它的逆问题,建反图做最大独立集. 对于A最多取出两 ...
随机推荐
- WIN2003服务器IIS下如何开启GZIP压缩
在上一篇文章黑客流谈到了关于网页打开速度对SEO的影响,其中提到了网页开启Gzip压缩的好处,接下来我来和大家分享一下WINDOWS系统IIS服务器下如何开启Gzip压缩. 首先我们来了解一下什么是G ...
- hdu 4000 树状数组
思路:找出所有 a<b<c||a<c<b的情况,在找出所有的a<b<c的情况.他们相减剩下就是a<c<b的情况了. #include<iostre ...
- 转: utf16编码格式(unicode与utf16联系)
转自: http://www.cnblogs.com/dragon2012/p/5020259.html UTF-16是Unicode字符集的一种转换方式,即把Unicode的码位转换为16比特长的码 ...
- Leetcode 338. Counting Bits
Given a non negative integer number num. For every numbers i in the range 0 ≤ i ≤ num calculate the ...
- Web Service 一些对外公开的网络服务接口
商业和贸易: 1.股票行情数据 WEB 服务(支持香港.深圳.上海基金.债券和股票:支持多股票同时查询) Endpoint: http://webservice.webxml.com.cn/WebSe ...
- 归约函数reduce&映射数组map(笔记)
function forEach(array,action){ ;i<array.length;i++) action(array[i]); } function reduce(combine, ...
- Servlet & JSP - 转发与重定向的区别
本文转载自:http://blog.csdn.net/kobejayandy/article/details/13762043 转发 转发的原理,可以通过下图展示: 浏览器的请求发送给组件 1,组件 ...
- hiho欧拉路·二 --------- Fleury算法求欧拉路径
hiho欧拉路·二 分析: 小Ho:这种简单的谜题就交给我吧! 小Hi:真的没问题么? <10分钟过去> 小Ho:啊啊啊啊啊!搞不定啊!!!骨牌数量一多就乱了. 小Hi:哎,我就知道你会遇 ...
- zookeeper启动报错(数据目录权限不对)
zookeeper启动报错日志: 2016-11-16 11:19:43,880 [myid:3] - INFO [WorkerReceiver[myid=3]:FastLeaderElection@ ...
- php5.4window下连接mssql
第一步 下载 http://www.microsoft.com/en-us/download/details.aspx?id=20098 [PHP_PDO_SQLSRV] extension=php_ ...