洛谷P2423 [HEOI2012]朋友圈
题目大意:
有\(A,B\)两个点集,每个点有点权,在\(A\)集合中,两个点之间有边满足\(a_i\ xor\ a_j\ mod\ 2 = 1\),在\(B\)集合中,两个点之间有边满足\(b_i\ xor\ b_j\ mod\ 2=0\)或者\(b_i\ or\ b_j\)化成二进制有奇数个\(1\)
求\(A,B\)集合的最大团的大小
第一类数据:\(|A|\le 200,|B|\le 200\)
第二类数据:\(|A|\le 10,|B|\le 3000\)
目前算法表示最大团问题是个\(NPC\)问题,所以我们不能直接解决
但是我们也许知道,最大团=补图最大独立集
考虑建立补图求最大独立集
对于\(A\)集合,在原图中奇偶不同的点之间有边,则在补图中奇偶相同的点之间全部有边,奇偶不同的点之间没有边,对于补图最大独立集,\(A\)图中最多选两个
对于\(B\)集合,在原图中奇偶相同的点之间有边,奇偶不同的点一些有边,则在补图中,奇偶相同的点之间没有边,我们可以以奇偶为划分标准将补图划分成二分图
建出补图后,因为\(A\)集合中点数很少,我们可以枚举\(A\)集合中选取的点,然后把与这些点构成完全图的\(B\)集合中的点标记,跑二分图最大独立集
略卡常,加时间戳优化
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
namespace red{
#define eps (1e-8)
inline int read()
{
int x=0;char ch,f=1;
for(ch=getchar();(ch<'0'||ch>'9')&&ch!='-';ch=getchar());
if(ch=='-') f=0,ch=getchar();
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return f?x:-x;
}
const int N=3010;
int haku;
int n,m,k,ret,tim,tim2;
int T[N];
int ap[N],bp[N];
bool jx[N][N];
bool jxb[N][N];
int vis[N<<2],f[N<<2];
int t3[N<<2];
int py[N],num;
int ans;
int head[N],cnt;
struct point
{
int nxt,to;
point(){}
point(const int &nxt,const int &to):nxt(nxt),to(to){}
}a[N*N];
inline void link(int x,int y)
{
a[++cnt]=(point){head[x],y};head[x]=cnt;
}
inline bool check(int x)
{
int sum=0;
for(;x;x-=(x&-x)) ++sum;
return sum&1;
}
inline bool find(int x)
{
for(int i=head[x];i;i=a[i].nxt)
{
int t=a[i].to;
if(vis[t]!=tim&&T[t]==tim2)
{
vis[t]=tim;
if(t3[t]!=tim||!f[t]||find(f[t]))
{
f[t]=x;
t3[t]=tim;
return 1;
}
}
}
return 0;
}
inline int solve()
{
int ret=0;
for(int i=1;i<=m;++i)
{
if(T[i]==tim2) ++tim,ret+=find(i);
else ++ret;
}
return m-ret;
}
inline void main()
{
haku=read();
while(haku--)
{
n=read(),m=read(),k=read();
for(int i=1;i<=n;++i) ap[i]=read();
for(int j=1;j<=m;++j) bp[j]=read();
for(int x,y,i=1;i<=k;++i)
{
x=read(),y=read();
jx[x][y]=1;
}
for(int i=1;i<=m;++i)
{
if(bp[i]&1)
{
for(int j=1;j<=m;++j)
{
if(!(bp[j]&1))
if(!check(bp[i]|bp[j])) link(i,j);
}
}
}
ret=max(ret,solve());
for(int i=1;i<=n;++i)
{
++tim2;
for(int j=1;j<=m;++j)
{
if(jx[i][j]) T[j]=tim2;
}
ret=max(ret,solve()+1);
}
for(int i=1;i<=n;++i)
{
if(ap[i]&1)
for(int j=i+1;j<=n;++j)
{
if(!(ap[j]&1))
{
++tim2;
for(int k=1;k<=m;++k)
{
if(jx[i][k]&&jx[j][k]) T[k]=tim2;
}
ret=max(ret,solve()+2);
}
}
}
printf("%d\n",ret);
}
}
}
signed main()
{
red::main();
return 0;
}
洛谷P2423 [HEOI2012]朋友圈的更多相关文章
- luogu P2423 [HEOI2012]朋友圈 (最大团)
在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目.两个国家看成是 ...
- bzoj 2744: [HEOI2012]朋友圈 二分图匹配
2744: [HEOI2012]朋友圈 Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 612 Solved: 174[Submit][Status] ...
- 【BZOJ 2744】 2744: [HEOI2012]朋友圈 (最大团,二分图匹配,构图)
2744: [HEOI2012]朋友圈 Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他 ...
- 【二分图】HEOI2012 朋友圈
题目内容 洛谷链接 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大 ...
- 洛谷 P1851 好朋友
题目背景 小可可和所有其他同学的手腕上都戴有一个射频识别序列号码牌,这样老师就可以方便的计算出他们的人数.很多同学都有一个“好朋友” .如果 A 的序列号的约数之和恰好等于B 的序列号,那么 A的好朋 ...
- 【BZOJ 2744 】[HEOI2012]朋友圈
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- BZOJ2744:[HEOI2012]朋友圈(最大团,乱搞)
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- 【刷题】BZOJ 2744 [HEOI2012]朋友圈
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- [HEOI2012]朋友圈
题目 我们发现我们要求的是一个最大团问题,众所周知这是一个\(NP\)难问题,除了爆搜没有什么别的方法,但是这道题我们可以根据图的特殊性质入手 我们如果把\(B\)国的人分成奇数和偶数两类,就会发现奇 ...
随机推荐
- GDB的原理
gdb调试不管是本地调试还是远程调试,都是基于ptrace系统调用来实现. ptrace系统调用提供了一种方法,让父进程可以观察和控制其它进程的执行,检查和改变其核心映像及寄存器.主要用来实现断点调试 ...
- 连续子数组的和的绝对值的最大值、最小值(非绝对值的话直接dp动态规划)
前缀和的思路: sum[i] = num[0]+num[1]+......+num[i-1] sum[j] = num[0]+num[1]+......+num[j-1] 那么:num[i]+num[ ...
- mysql参数总结
1.innodb_old_blocks_pct 确定modpoint位置,默认37,(3/8=37%)可以通过这个调整young与old比. innodb_old_blocks_time:当有大的查询 ...
- ceph卡在active+remapped状态
最近看到了有人的环境出现了出现了卡在active+remapped状态,并且卡住不动的状态,从pg的状态去看,这个pg值分配了主的pg,没有分配到副本的osd,集群的其他设置一切正常 这个从网上搜寻到 ...
- Nacos配置中心源码分析
1.使用 compile 'com.alibaba.cloud:spring-cloud-starter-alibaba-nacos-config:2.2.3.RELEASE' spring: app ...
- deepin 安装最新版node
安装npm sudo apt install npm 安装node sudo npm install -g n 升级node到稳定版 sudo n stable 升级到最新版 sudo n lates ...
- beef抓包简析
搭建完了beef就想简答的抓下包分析下 这是第一个包,追踪它 返回demo页面,并发现其中的脚本 window.location.protocol表示协议http, window.location.h ...
- 朴素的模式匹配算法BF
1 #include <iostream> 2 using namespace std; 3 int BF(char S[], char T[]); 4 int main() 5 { 6 ...
- 新手上路之JDK8的下载、安装与PATH环境变量的配置
有些东西不常用总是会忘记,所以想把它写下来,方便以后自己想用的时候找得到:同时也进一步加深自己的记忆.接触JAVA的时间不长,言语或内容有不当之处,欢迎大佬们指正. 每一个学习JAVA的人都会经历的过 ...
- 五. Webpack详解
1. 什么是Webpack 1.1 引入 什么是webpack?这个webpack还真不是一两句话可以说清楚的. 我们先看看官方的解释:At its core, webpack is a static ...