【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最多取出两 ...
随机推荐
- Adobe Edge Animate –EdgeCommons Log和全局变量设置功能
Adobe Edge Animate –EdgeCommons Log和全局变量设置功能 版权声明: 本文版权属于 北京联友天下科技发展有限公司. 转载的时候请注明版权和原文地址. 一.Log功能 当 ...
- Adobe Edge Animate –Edge Commons强势来袭,Edge团队开发成为现实
Adobe Edge Animate –Edge Commons强势来袭,Edge团队开发成为现实 版权声明: 本文版权属于 北京联友天下科技发展有限公司. 转载的时候请注明版权和原文地址. Edge ...
- CF Theatre Square
Theatre Square time limit per test 2 seconds memory limit per test 64 megabytes input standard input ...
- [改善Java代码] 枚举项数量限定为64个以内
建议89:枚举项的数量限制在64个以内 为了更好的使用枚举,java 提供了两个枚举集合:EnumSet和EnumMap,这两个集合的使用都比较简单,EnumSet表示其元素必须是某一枚举的枚举项,E ...
- ECharts地图详解 【转】
$(function() { // 路径配置 require.config({ paths : { // echarts: 'http://echarts.baidu.com/build/dist' ...
- ViewPager的基本使用--可左右循环切换也可自动切换
ViewPager也算是Android自带的常用控件之一,但是有可能会无法直接调用,所以只需要将工程目录里/libs/android-support-v4.jar该jarAdd to Build Pa ...
- Android之图片应用
package com.example.imagescale; import android.os.Bundle; import android.app.Activity; import androi ...
- WaitForSingleObject用法
对应函数 编辑 VC声明 DWORD WaitForSingleObject( HANDLE hHandle, DWORD dwMilliseconds ); 参数 编辑 hHandle[in]对 ...
- 指针与strncpy---内存
指针的形式的赋值和strncpy的赋值 e.SetAttr("Amt", ToString(dAmt) ); e.SetAttr("Amt", sAm ...
- CICS日志---内存问题
Level 9 COCITOOL_XA: Connected! [2014-01-09 19:46:24.296834][22347888] Level 0 TestPerormence: GDAO ...