BZOJ 1854: [Scoi2010]游戏(二分图匹配/并查集)
题面:
https://www.lydsy.com/JudgeOnline/problem.php?id=1854
题解:
1.二分图匹配:
首先我们发现每件装备只能在两种属性中选一种。因此,我们以每个装备的编号向两种属性分别连边。然后用1-n的属性分别进行向装备的匹配,一旦有一种匹配不上就退出。
代码:
#include<bits/stdc++.h> using namespace std; const int maxn=;
int head[maxn],vis[maxn],fa[maxn],ans,cnt,n,maxx; struct ed{
int next,to;
}e[maxn<<]; void add(int u,int v){
e[++cnt]=(ed){head[u],v};
head[u]=cnt;
} bool hungary(int now,int sign){
for(int i=head[now];i;i=e[i].next){
int tt=e[i].to;
if(vis[tt]==sign) continue;
vis[tt]=sign;
if(!fa[tt]||hungary(fa[tt],sign)){
fa[tt]=now;
return ;
}
}
return ;
} int main(){
scanf("%d",&n);
int u,v;
for(int i=;i<=n;i++){
scanf("%d%d",&u,&v);
add(u,i),add(v,i);
maxx=max(maxx,max(u,v));
}
for(int i=;i<=maxx;i++){
if(!hungary(i,i))
break;
ans++;
}
printf("%d",ans);
return ;
}
2.并查集:
同样的,每种装备的两个属性只能选一个,那么,我们可以将每一种装备看做一条将两种属性相连的边。很显然,这些属性被分成了一个个的联通块。那么不难发现,只有当一个联通块内有环时,这个联通块才能每个属性都被选中,否则(即为一棵树)必须有一个不选,显然不选编号最大的最优。又因为每个点在且仅在一个联通块(单独的一个点也算一个联通块),所以这就满足了并查集的要求。
代码:
#include<bits/stdc++.h> using namespace std; const int maxn=;
int fa[maxn],val[maxn],ans,n; int ffa(int x){
return fa[x]==x?x:fa[x]=ffa(fa[x]);
} int main(){
scanf("%d",&n);
for(int i=;i<=n;i++)
fa[i]=i;
int u,v;
for(int i=;i<=n;i++){
scanf("%d%d",&u,&v);
int fu=ffa(u),fv=ffa(v);
if(fu==fv)
val[fu]++;
else{
fa[fv]=fu;val[fu]++;
val[fu]+=val[fv];
val[fv]=;
}
}
for(int i=;i<=n;i++)
if(val[ffa(i)])
ans++,val[ffa(i)]--;
else break;
printf("%d",ans);
return ;
}
算法比较:
上面是二分图匹配,下面是并查集
BZOJ 1854: [Scoi2010]游戏(二分图匹配/并查集)的更多相关文章
- BZOJ 1854: [Scoi2010]游戏( 二分图最大匹配 )
匈牙利算法..从1~10000依次找增广路, 找不到就停止, 输出答案. --------------------------------------------------------------- ...
- bzoj 1854 游戏 二分图匹配 || 并查集
题目链接 Description lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的 ...
- HDU-3081-Marriage Match II 二分图匹配+并查集 OR 二分+最大流
二分+最大流: 1 //题目大意:有编号为1~n的女生和1~n的男生配对 2 // 3 //首先输入m组,a,b表示编号为a的女生没有和编号为b的男生吵过架 4 // 5 //然后输入f组,c,d表示 ...
- BZOJ 1854: [Scoi2010]游戏 并查集
1854: [Scoi2010]游戏 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 2672 Solved: 958[Submit][Status][ ...
- BZOJ 1854: [Scoi2010]游戏 无向图判环
题目链接: 题目 1854: [Scoi2010]游戏 Time Limit: 5 Sec Memory Limit: 162 MB 问题描述 lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装 ...
- BZOJ 1854: [Scoi2010]游戏 [连通分量 | 并查集 | 二分图匹配]
题意: 有$n \le 10^6$中物品,每种两个权值$\le 10^4$只能选一个,使得选出的所有权值从1递增,最大递增到多少 一开始想了一个奇怪的规定流量网络流+二分答案做法...然而我还不知道怎 ...
- bzoj 1854: [Scoi2010]游戏 (并查集||二分图最大匹配)
链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1854 写法1: 二分图最大匹配 思路: 将武器的属性对武器编号建边,因为只有10000种 ...
- [BZOJ1854][Scoi2010]游戏(二分图匹配/并查集)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1854 分析:很裸的一道二分图匹配对吧,但是在hzwer的blog上看见神奇的并查集做法 ...
- ●BZOJ 1854 [Scoi2010]游戏
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1854 题解: 并查集(还可以用匈牙利算法进行单路增广的二分图匹配) 把每个武器看成是一条边, ...
随机推荐
- IIS下载地址
https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=1038
- Vue 刷新当前页面,并重新加载页面数据
业务场景:在管理后台,在执行完,增,删,改,操作的时候.我们需要刷新一下页面,重载数据.在JQ中我们会用到location.reload()方法,刷新页面:在vue中,这里需要用到一个 provide ...
- JS学习笔记 等于和包装对象
严格等于 a===b 首先判断两边数据的类型,若类型不同,返回false. 若类型相同(1.2和1.2,字符串相等指内容和长度都是一样的),返回true null===null undefined== ...
- Golang的Json encode/decode以及[]byte和string的转换
使用了太长时间的python,对于强类型的Golang适应起来稍微有点费力,不过操作一次之后发现,只有这么严格的类型规定,才能让数据尽量减少在传输和解析过程中的错误.我尝试使用Golang创建了一个公 ...
- 三星 SCX-4521NS 网络打印机 在XP 下 强行 设置 安装
添加打印机加上之后,图标是半虚的,状态脱机,网上找了很多方法都不好使. 包括官方的:http://www.samsung.com/cn/support/skp/faq/442292 然后死马当活马医, ...
- axis函数
axis函数 axis([xmin xmax ymin ymax]) 用来标注输出的图线的最大值最小值. MATLAB中坐标系的设置函数 MATLAB 函数 axis([XMIN XMAX YMI ...
- codeforces509B
Painting Pebbles CodeForces - 509B There are n piles of pebbles on the table, the i-th pile contains ...
- mysql,mybatis模糊查询
<if test="deviceType != null and deviceType != ''">and device_type like CONCAT('%', ...
- nginx-添加禁止访问规则
location ~* /application/(admin|index)/static/.*$ { allow all; } location ~* /(applicaion|addos|coe| ...
- Codeforces Round #446 Div. 1
B:即使看到n<=22也应该猜到这只是为了写spj.将每个数替换为恰好比他大的数即可,最大值替换为最小值.这样原序列中不包含最小值的集合显然都满足条件,并且容易发现包含最小值的集合的变化量都是最 ...