关注
//第一题并查集思路,供参考
#include <stdio.h>
#define N 100020
int friends[N];//每个人所属的连通分量,即构成朋友树时每个人的父节点
int rank[N];//连通分量的权值,即朋友树的大小
int res;
void init(int n)//初始化initialization
{
for(int i=0;i<n;i++)
{
friends[i]=i;
rank[i]=0;
}
}
int findRoot(int x)//寻找x所属的朋友树的根节点
{
//一直向上遍历寻找根节点
while(x != friends[x])
x = friends[x];
return x;
}
void connect(int x,int y)
{
int xRoot = findRoot(x);
int yRoot = findRoot(y);
if(xRoot == yRoot)
return ;
//判断树高,小树并在大树下
if(rank[xRoot] < rank[yRoot])
friends[xRoot]=yRoot;
else
{
friends[yRoot] = xRoot;
if(rank[xRoot]==rank[yRoot])//两树高相等,合并后树高+1
rank[xRoot]++;
}
--res;
}
int main()
{
int n;
init(N);//初始化
scanf("%d",&n);
res = n;
for(int i=1;i<=n;i++){
int t;
while(~scanf("%d",&t)){
if(t == 0)
break;
connect(i,t);
}
}
printf("%d",res);
return 0;
}
查看原帖
点赞 评论
相关推荐
09-06 12:49
门头沟学院 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 从顶到拉给所有面过的公司评分 #
13249次浏览 124人参与
# 机械人春招想让哪家公司来捞你? #
356873次浏览 3104人参与
# 为了求职,我做过的疯狂伪装 #
10396次浏览 171人参与
# 晒晒你的中秋福利 #
14721次浏览 91人参与
# 职场破冰,你们都聊什么? #
5940次浏览 58人参与
# 工作压力大怎么缓解 #
104737次浏览 1048人参与
# 机械人怎么评价今年的华为 #
208544次浏览 1524人参与
# bilibili求职进展汇总 #
84845次浏览 780人参与
# 广联达求职进展汇总 #
10651次浏览 50人参与
# 大家实习每天都在干啥 #
88663次浏览 517人参与
# 你面试被问到过哪些不会的问题? #
18603次浏览 731人参与
# 聊聊这家公司值得去吗 #
553393次浏览 3676人参与
# 秋招报数:你投了多少家公司? #
26286次浏览 266人参与
# 实习要如何选择和准备? #
114441次浏览 1436人参与
# 秋招OC许愿 #
345574次浏览 2523人参与
# 秋招的嫡长offer #
25614次浏览 247人参与
# 上班后和你想的一样吗? #
79124次浏览 630人参与
# 电网笔面经互助 #
46385次浏览 428人参与
# 你觉得早上几点上班合适? #
82272次浏览 329人参与
# 上班摸鱼,你都在干些什么? #
6013次浏览 103人参与