首页 技术 正文
技术 2022年11月9日
0 收藏 306 点赞 5,167 浏览 867 个字

题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1529

题意:

  Byteazar有N个小猪存钱罐。

  每个存钱罐只能用钥匙打开或者砸开。

  Byteazar已经把每个存钱罐的钥匙放到了某些存钱罐里。

  Byteazar 现在想买一台汽车于是要把所有的钱都取出来。

  他想尽量少的打破存钱罐取出所有的钱,问最少要打破多少个存钱罐。

题解:

  并查集。

  

  如果打开a的钥匙放在b中,那么如果打开了b,a也能打开。

  所以将a的认爹箭头指向b。

  

  对于一个集合,只要打开了这个集合的老大,那么其他的就都能打开。

  所以答案为集合个数。也就是统计find(i) == i的点的个数。

AC Code:

 #include <iostream>
#include <stdio.h>
#include <string.h>
#define MAX_N 1000005 using namespace std; int n;
int ans=;
int par[MAX_N]; void init_union_find()
{
for(int i=;i<=n;i++)
{
par[i]=i;
}
} int find(int x)
{
return par[x]==x?x:par[x]=find(par[x]);
} void unite(int x,int y)
{
int px=find(x);
int py=find(y);
if(px==py) return;
par[px]=py;
} bool same(int x,int y)
{
return find(x)==find(y);
} void read()
{
cin>>n;
init_union_find();
int a;
for(int i=;i<=n;i++)
{
cin>>a;
unite(i,a);
}
} void solve()
{
for(int i=;i<=n;i++)
{
if(find(i)==i) ans++;
}
} void print()
{
cout<<ans<<endl;
} int main()
{
read();
solve();
print();
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,492
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,493
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,132
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,295