bzoj 2744: [HEOI2012]朋友圈 二分图匹配
2744: [HEOI2012]朋友圈
Time Limit: 30 Sec Memory Limit: 128 MB
Submit: 612 Solved: 174
[Submit][Status][Discuss]
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国跑匈牙利是可以过的,只是提醒一个坑:出题人貌似专门卡了匈牙利,如果TLE掉了试一试换一个集合调用find函数。原来我在b[i]%2==0时调用find(i)TLE,然后换成b[i]%2==1就行了。
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<vector>
using namespace std;
#define MAXN 3100
#define MAXV MAXN
#define MAXE 11000000
struct Edge
{
int np;
Edge *next;
}E[MAXE],*V[MAXV];
int tope=-;
void addedge(int x,int y)
{
E[++tope].np=y;
E[tope].next=V[x];
V[x]=&E[tope];
}
vector<int> blst[MAXN];
int a[MAXN],b[MAXN];
int vis[MAXN],vistime;
int ptr[MAXN];
bool find(int now)
{
if (vis[now]==vistime)return false;
vis[now]=vistime;
Edge *ne;
for (ne=V[now];ne;ne=ne->next)
{
if (ptr[ne->np]==- || find(ptr[ne->np]))
{
ptr[ne->np]=now;
return true;
}
}
return false;
}
int work(vector<int> seq)
{
for (int i=;i<seq.size();i++)ptr[seq[i]]=-;
for (int i=;i<seq.size();i++)
{
for (int j=i+;j<seq.size();j++)
{
if (((b[seq[i]]^b[seq[j]])&) && !__builtin_parity(b[seq[i]]|b[seq[j]]))
{
addedge(seq[i],seq[j]);
addedge(seq[j],seq[i]);
}
}
}
int ret=;
for (int i=;i<seq.size();i++)
{
if ((b[seq[i]]&))
{
++vistime;
ret+=find(seq[i]);
}
}
ret=seq.size()-ret;
for (int i=;i<seq.size();i++)V[seq[i]]=;tope=-;
return ret;
} int ans=;
int main()
{
freopen("input.txt","r",stdin);
freopen("output.txt","w",stdout);
int n,m,q;
int x,y;
vector<int> seq;
scanf("%d%d",&n,&m);
scanf("%d",&q);
for (int i=;i<=n;i++)
scanf("%d",a+i);
for (int i=;i<=m;i++)
scanf("%d",b+i);
for (int i=;i<=n;i++)blst[i].clear();
for (int i=;i<=q;i++)
{
scanf("%d%d",&x,&y);
blst[x].push_back(y);
}
for (int i=;i<=n;i++)
{
sort(blst[i].begin(),blst[i].end());
blst[i].erase(unique(blst[i].begin(),blst[i].end()),blst[i].end());
}
//Nothing In A
for (int i=;i<=m;i++)seq.push_back(i);
ans=max(ans,work(seq));
seq.clear();
for (int i=;i<=n;i++)
{
for (int j=;j<blst[i].size();j++)
seq.push_back(blst[i][j]);
if (seq.size()+>ans)
ans=max(ans,work(seq)+);
seq.clear();
}
for (int i=;i<=n;i++)
{
for (int j=i+;j<=n;j++)
{
if (!((a[i]^a[j])&))continue;
vector<int> :: iterator it1,it2;
it1=blst[i].begin();
it2=blst[j].begin();
while (it1!=blst[i].end() && it2!=blst[j].end())
{
if (*it1==*it2)
{
seq.push_back(*it1);
it1++,it2++;
}else if (*it1<*it2)
{
it1++;
}else
{
it2++;
}
}
if (seq.size()+>ans)
ans=max(ans,work(seq)+);
seq.clear();
}
}
printf("%d\n",ans);
}
bzoj 2744: [HEOI2012]朋友圈 二分图匹配的更多相关文章
- 【刷题】BZOJ 2744 [HEOI2012]朋友圈
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- bzoj2744 [HEOI2012]朋友圈——二分图匹配
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2744 首先,求一个图的最大团等价于求它的补图的最大独立集,而二分图的最大独立集 = 总点数 ...
- 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 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他 ...
- 【BZOJ 2744 】[HEOI2012]朋友圈
Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最 ...
- BZOJ2744 HEOI2012朋友圈(二分图匹配)
先考虑B国.容易发现a xor b mod 2=0即二进制末位相同,那么可以据此将所有人分成两部分,每一部分各自是一个完全图.然后再将a or b有奇数个1的边连上,现在需要求的就是这样一个图里的最大 ...
- 【二分图】HEOI2012 朋友圈
题目内容 洛谷链接 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大 ...
- luogu P2423 [HEOI2012]朋友圈 (最大团)
在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着. 一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目.两个国家看成是 ...
随机推荐
- 实现Foreach遍历
实现Foreach遍历的集合类,需要实现IEnumerable接口,泛型集合则需要实现IEnumerable<T>接口 using System; using System.Collect ...
- Bootstrap 标签的变体 实例样式
Bootstrap 标签样式,代码如下: <!DOCTYPE html> <html> <head> <title>Bootstrap 实例 - 标签的 ...
- 找个输入IPoint在某个FeatureClass上距离最近的要素
/// <summary> /// 得到输入点在输入图层上的最近点 /// </summary> /// <param name="randomPoints ...
- 韩顺平细说Servlet视频系列意外收获之用命令行编译带有包的java类解决方案
命令行编译带有包的java类 在命令行编译这一块,基本上都是新手入门时了解一下,然后就直奔IDE而去.这样固然没错,就怕那些--.然后今天在视频中看到了这种方法,觉得可能会用到,所以就记录下来了,以备 ...
- CMake基础教程
如果需要配置和检查我们工程中的所有依赖,那么可以选用CMake工具:但是,这并不是必须的,因为我们可以使用其他的工具或者是IDE(比如Makefiles或者Visual Studio)来配置我们的工程 ...
- JS焦点图,JS 多个页面放多个焦点图
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- OWIN and Katana - 1
翻译自 http://www.asp.net/aspnet/overview/owin-and-katana/an-overview-of-project-katana 十多年来,基于ASP.NET框 ...
- canvas 的学习
canvas 绘制直线的API有: 1.moveTo()起点坐标. 2.lineTo()绘制的直线 3. fillStyle以及 flii()是绘制实体的 4. strokeStyle 和stroke ...
- php 操作数组 (合并,拆分,追加,查找,删除等)
1. 合并数组 array_merge()函数将数组合并到一起,返回一个联合的数组.所得到的数组以第一个输入数组参数开始,按后面数组参数出现的顺序依次迫加.其形式为: array array_merg ...
- 写文件前, 检查目录写权限(PHP)
写文件前, 检查目录写权限 写或保存文件前, 确保目录是可写的, 假如不可写, 输出错误信息. 这会节约你很多调试时间. linux系统中, 需要处理权限, 目录权限不当会导致很多很多的问题, 文件也 ...