【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最多取出两 ...
随机推荐
- zabbix电话告警V1
最近决定将夜班值班人员取消,夜里告警采用机器人电话通知.总结一下这么几个情况,有问题还请指出,希望也能给大家多一个思路. V1做的太糙了,预计年初上V2 一.用谁家的服务 费用我没有太关注,主要就是看 ...
- PE制作实录 —— 补充说明
上一篇博文中我提到了定制 PE 合盘的方法,可能还有一些朋友不是很懂,这里补充几点. 要点1: 菜单的排布 U盘启动时的界面,这里叫做主界面,而主界面下有时还会用到子界面,下面是我制作的PE的菜单目录 ...
- 理解Android系统的进程间通信原理(一)----RPC中的代理模式
Android系统中的进程间通信是通过一个轻量级的RPC(Remote Procedure Call远程进程调用)和AIDL(Android Interface Definination Langua ...
- ORA-01790 错误处理
今天在练手的时候出现了一个ORA-01790 的错误,决定把他写下来保留起来. 先来创建两张测试用的简单的表. SQL> create table test01 (id number(3),na ...
- .net 获取网站根目录总结
一.获取网站根目录的方法有几种如: Server.MapPath(Request.ServerVariables["PATH_INFO"]) //页面详细路 Server.MapP ...
- 【Cocos2d入门教程五】Cocos2d-x动作篇
动作类(Action)是所有动作的基类,它创建的一个对象代表一个动作.动作作用于Node,包括继承于之下的Layer.Sprite.因此每个动作 都需要由Node对象或者其继承者执行.动作类(Acti ...
- Access和Sql区别
假设表game有一字段为gameYuiJian为bit字段(SQL SERVER 20005)和"是/否"字段(ACCSS数据库),在编写脚本文件时,如下才能正确执行 SQL st ...
- SQL server 2008 安装问题解决
安装sqlserver2008 出现的一些问题解决方法 1,安装sqlserver的时候出现如下图所示,解决办法是:开始→运行→输入“regedit”→找到“HKEY_LOCAL_MACHINE\SY ...
- UIDynamic 基础认识
UIDynamic 是从iOS 7开始引入的一种新技术,属于UIKit框架,可以模拟现实生活中的物理现象,如:碰撞.抖动.摆动等 动力效果:有一个效果器,叫做“动力效果器”里面面可以添加“动力效果” ...
- 使用JS调用WebService接口
<script> $(document).ready(function () { var username = "admin"; var password = &quo ...