problem

luogu-P2423

solution

本题即求无向图最大团问题。这是个 NP hard\text{NP hard}NP hard 问题,所以必须从图的特殊性质出发,否则只能暴搜。

异或运算等价于二进制下不进位的加法运算。

observation1:\text{observation1}:observation1: AAA 国人之间做朋友的条件等价于两人的 aia_iai​ 奇偶性不同。

observation2:\text{observation2}:observation2: 基于上一条,我们可以得出最大朋友圈中 AAA 国人数只可能包含 0/1/20/1/20/1/2 人。

observation3:\text{observation3}:observation3: BBB 国人的限制有两种,且是各自独立的。

observation4:\text{observation4}:observation4: 将 BBB 国人按照 bib_ibi​ 的奇偶性分类,则两类之间的人一定都是两两可以做朋友的。

observation5:\text{observation5}:observation5: 而第二种限制的朋友关系则是一个在奇数类一个在偶数类。

BBB 国分类后的情况形似二分图。

只不过二分图是,左右内部两两无边,然后有连接左右的边。

这里是左右内部两两有边,然后有连接左右的边。

observation6:\text{observation6}:observation6: 原图的补图是个二分图,且原图的最大团等于补图的最大独立集。

最大团是两两有边,最大独立集是两两无边,感觉上原图的最大团就应该等于补图的最大独立集。

严谨证明可自行百度。

而二分图的最大独立集又等于二分图的最小点覆盖。

而二分图的最小点覆盖又等于总点数减去最大匹配数。

所以问题就变成了求补图(二分图)的最大匹配数,网络流即可。

至于 AAA 国的人,直接枚举是选 0/1/20/1/20/1/2 个人,然后每次重新建图跑网络流即可。

因为有 AAA 国人的存在,所以只用考虑与枚举的 AAA 国人是朋友的 BBB 国人跑网络流即可。

具体可以看代码实现。

code

#include <bits/stdc++.h>
using namespace std;
#define maxn 3005
int T, A, B, M, s, t, cnt, ans, tot;
queue < int > q;
vector < int > G[maxn];
pair < int, int > e[maxn * maxn];
struct node { int to, nxt, flow; }E[maxn * maxn];
int head[maxn], cur[maxn], dep[maxn], vis[maxn], a[maxn], b[maxn];
int g[2][maxn];void addedge( int u, int v ) {E[++ cnt] = { v, head[u], 1 }, head[u] = cnt;E[++ cnt] = { u, head[v], 0 }, head[v] = cnt;
}bool bfs() {memset( dep, 0, sizeof( dep ) );memcpy( cur, head, sizeof( head ) );dep[s] = 1; q.push( s );while( ! q.empty() ) {int u = q.front(); q.pop();for( int i = head[u];~ i;i = E[i].nxt ) {int v = E[i].to;if( ! dep[v] and E[i].flow ) dep[v] = dep[u] + 1, q.push( v );}}return dep[t];
}int dfs( int u, int cap ) {if( u == t or ! cap ) return cap;int flow = 0;for( int i = cur[u];~ i;i = E[i].nxt ) {int v = E[i].to; cur[u] = i;if( dep[v] == dep[u] + 1 ) {int w = dfs( v, min( cap, E[i].flow ) );if( ! w ) continue;E[i ^ 1].flow += w;E[i].flow -= w;flow += w;cap -= w;if( ! cap ) break;}}return flow;
}void dinic( int n ) {while( bfs() ) {n -= dfs( s, 1e9 );//总点数-最大匹配 才是要求的补图的最小点覆盖 即原图的最大团if( n <= ans ) return;}ans = n;
}void build() {cnt = -1, memset( head, -1, sizeof( head ) );for( int i = 1;i <= tot;i ++ )if( vis[e[i].first] and vis[e[i].second] )addedge( e[i].first, e[i].second );for( int i = 1;i <= g[0][0];i ++ ) if( vis[g[0][i]] ) addedge( s, g[0][i] );for( int i = 1;i <= g[1][0];i ++ ) if( vis[g[1][i]] ) addedge( g[1][i], t );
}int main() {scanf( "%d", &T );while( T -- ) {scanf( "%d %d %d", &A, &B, &M );for( int i = 1;i <= A;i ++ ) G[i].clear();s = 0, t = B + 1, ans = tot = g[0][0] = g[1][0] = 0;for( int i = 1;i <= A;i ++ ) scanf( "%d", &a[i] );for( int i = 1;i <= B;i ++ ) scanf( "%d", &b[i] );for( int i = 1, x, y;i <= M;i ++ ) {scanf( "%d %d", &x, &y );G[x].push_back( y );}for( int i = 1;i <= B;i ++ ) g[b[i]&1][++g[b[i]&1][0]] = i;for( int i = 1;i <= g[0][0];i ++ )for( int j = 1;j <= g[1][0];j ++ )if( __builtin_popcount( b[g[0][i]] | b[g[1][j]] ) & 1 )continue;elsee[++ tot] = make_pair( g[0][i], g[1][j] );for( int i = 1;i <= B;i ++ ) vis[i] = 1;build(), dinic( B ); //一个A类人都不选for( int i = 1;i <= A;i ++ ) { //枚举选的一个A类人memset( vis, 0, sizeof( vis ) );for( int x : G[i] ) vis[x] ++;int n = 1;//n当前情况的总点数for( int j = 1;j <= B;j ++ ) n += vis[j];if( n <= ans ) continue;else build(), dinic( n );}for( int i = 1;i <= A;i ++ )for( int j = i + 1;j <= A;j ++ )if( ( a[i] ^ a[j] ) & 1 ) {//枚举选择两个A类人memset( vis, 0, sizeof( vis ) );for( int x : G[i] ) vis[x] ++;for( int x : G[j] ) vis[x] ++;int n = 2;for( int k = 1;k <= B;k ++ )if( vis[k] < 2 ) vis[k] = 0;else vis[k] = 1, n ++;if( n <= ans ) continue;else build(), dinic( n );}printf( "%d\n", ans );}return 0;
}

[HEOI2012] 朋友圈(最大团 + 结论 + 二分图 + 网络流)相关推荐

  1. luogu P2423 [HEOI2012]朋友圈 (最大团)

    在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目.两个国家看成是 ...

  2. 解题报告:luogu P2423 [HEOI2012]朋友圈【最大团转最大点独立集(匈牙利算法+时间戳优化)】

    图的最大团:"任意两点之间都有一条边相连"的子图被称为无向图的团,点数最多的团为图的最大团 朋友圈中任意两个点之间都有关系,既是图中的团. 答案就是图中的最大团. 我们如果把B国的 ...

  3. 【BZOJ 2744 】[HEOI2012]朋友圈

    Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...

  4. bzoj2744[HEOI2012]朋友圈

    题目链接:bzoj2744 题目大意: 两个国家看成是AB两国,现在是两个国家的描述: 1.A国:每个人都有一个友善值,当两个A国人的友善值a.b,如果a xor b mod 2=1,那么这两个人都是 ...

  5. BZOJ 2744: [HEOI2012]朋友圈

    传送门 解题思路 直接跑最大团洛谷上能得70分,惊了.说说正解,首先A国的必须xor后mod2余1,就相当于两个人必须是1奇1偶,所以A国的人只能选0,1,2个,我们可以暴力枚举选谁.继续考虑B国,现 ...

  6. HEOI2012 朋友圈

    这是做的最得意的一道题,当时在考场上得了90,是因为数据中A有100++的情况,Runtime_error了.. 首先强调,本人不是用二分图,或者说不用图论算法,只涉及简单的枚举和记忆化思想. A国的 ...

  7. cogs 2620. [HEOI2012]朋友圈

    /*70分 被卡T*/ #include<iostream> #include<cstdio> #include<cstring> using namespace ...

  8. BZOJ2744洛谷P2423P2423 [HEOI2012]朋友圈

    自从有了课件,我就不想打字了 代码(交在BZOJ的时候记得把组数删掉) //By AcerMo%%%尹兄 #include<cmath> #include<cstdio> #i ...

  9. BZOJ - 2744 朋友圈 (二分图上的最大团)

    [题目大意] 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目. ...

最新文章

  1. 前端工程化系列[02]-Grunt构建工具的基本使用
  2. 创业者周鸿祎前传(西安交大时期)
  3. uc3842开关电源电路图_UC3842构成的开关电源电路
  4. python学习笔记(四)——流程控制
  5. 共识协议(6)PBFT详细步骤
  6. NVIDIA ECCV18论文:超像素采样网络助力语义分割与光流估计(代码将开源)
  7. 简单的Vue计算属性
  8. 汇编学习--7.16--int指令
  9. 图解 FAT 文件系统基础知识
  10. 《数据结构与面向对象程序设计》第二、三周学习总结
  11. 计算机培训excel的制作,绵阳电脑excel表格制作教程
  12. 如何修改web浏览器title文字及icon
  13. 登录注册页面html模版
  14. 【Java成王之路】EE进阶第十篇 MyBatis查询数据库
  15. revel MySQL_Revel 教程
  16. 齐齐哈尔大学考研计算机专业,齐齐哈尔大学(专业学位)计算机技术研究生考试科目和考研参考书目...
  17. CSAPP Lab2 实验记录 ---- Bomb Lab(Phase 1 - Phase 6详细解答 + Secret Phase彩蛋解析)
  18. java holder详解,Java基础系列18:Holder技术的实现原理分析
  19. 微信用户授权及企业付款
  20. OPA1611AIDR IC AUDIO 1 CIRCUIT 8SOIC

热门文章

  1. 备战数学建模国赛,快速搞定算法模型!
  2. 李国庆离开当当,广东消委会告长隆,智能校服提供定位功能,全球首个5G火车站来了,这就是今天的大新闻...
  3. 预售┃连锁反应装置积木好玩到尖叫!
  4. 深夜,学妹说她想做Python数据分析师
  5. 有趣!机器学习预测《守望先锋》里的赢家
  6. 熬夜族又一噩耗:“早死”风险更高!
  7. 电脑睡眠快捷键_电脑快速进入睡眠的快捷键是什么?
  8. java模拟火车站买票的过程_Java常用代理
  9. leetcode98. 验证二叉搜索树
  10. 7-2 作业调度算法--短作业优先 (30 分)(思路+详解+vector容器做法)Come Baby!!!!!!!!!!!