在乙個社群裡,每個人都有自己的小圈子,還可能同時屬於很多不同的朋友圈。我們認為朋友的朋友都算在乙個部落裡,於是要請你統計一下,在乙個給定社群中,到底有多少個互不相交的部落?並且檢查任意兩個人是否屬於同乙個部落。
輸入格式:
輸入在第一行給出乙個正整數n(≤10
4 ),是已知小圈子的個數。隨後n行,每行按下列格式給出乙個小圈子裡的人:
k p[1] p[2] ⋯ p[k]
其中k是小圈子裡的人數,p[i](i=1,⋯,k)是小圈子裡每個人的編號。這裡所有人的編號從1開始連續編號,最大編號不會超過10
4 。
之後一行給出乙個非負整數q(≤10
4 ),是查詢次數。隨後q行,每行給出一對被查詢的人的編號。
輸出格式:
首先在一行中輸出這個社群的總人數、以及互不相交的部落的個數。隨後對每一次查詢,如果他們屬於同乙個部落,則在一行中輸出y,否則輸出n。
輸入樣例:
4 3 10 1 2
2 3 4
4 1 5 7 8
3 9 6 4
2 10 5
3 7
輸出樣例:
10 2 y n
分析:求部落數和總人數
使用並查集 + 標記
**:
#include
using
namespace
std;
#define mem(a,n) memset(a,n,sizeof(a))
#define memc(a,b) memcpy(a,b,sizeof(b))
#define rep(i,a,n) for(int i=a;i///[a,n)
#define pb push_back
#define io ios::sync_with_stdio(false)
#define fre freopen("in.txt","r",stdin)
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
typedef
long
long ll;
typedef
unsigned
long
long ull;
const
double pi=acos(-1.0);
const
double e=2.718281828459045;
const
double eps=1e-8;
const
int inf=0x3f3f3f3f;
const
int mod=1e8+7;
const
int n=1e4+5;
const ll maxn=1e6+5;
const
int dir[4][2]= ;
int n,k,q,par[n];
bool vis[n];
int find(int x)///遞迴的常規寫法會t
return rt;
}void unite(int x,int y)
bool same(int x,int y)
void init()
int main()
}int cnt=0,ans=0;
rep(i,1,10001)
printf("%d %d\n",cnt,ans);
scanf("%d",&q);
while(q--)
return
0;}
天梯賽L2 024 部落 並查集
在乙個社群裡,每個人都有自己的小圈子,還可能同時屬於很多不同的朋友圈。我們認為朋友的朋友都算在乙個部落裡,於是要請你統計一下,在乙個給定社群中,到底有多少個互不相交的部落?並且檢查任意兩個人是否屬於同乙個部落。輸入格式 輸入在第一行給出乙個正整數n 10 4 是已知小圈子的個數。隨後n行,每行按下列...
PTA天梯賽L2 024 部落 並查集
在乙個社群裡,每個人都有自己的小圈子,還可能同時屬於很多不同的朋友圈。我們認為朋友的朋友都算在乙個部落裡,於是要請你統計一下,在乙個給定社群中,到底有多少個互不相交的部落?並且檢查任意兩個人是否屬於同乙個部落。輸入在第一行給出乙個正整數n 10 4 是已知小圈子的個數。隨後n行,每行按下列格式給出乙...
PAT 天梯賽 L2 024 部落 並查集
題目鏈結 題意 給出 幾個不同的圈子,然後 判斷 有哪些人 是屬於同乙個部落的,或者理解為 有哪些人 是有關係的,朋友的朋友 也屬於同乙個部落 思路 用並查集 並,然後最後查一下 有幾個連通塊,就可以輸出有幾個互不相交的部落,然後最後判斷兩個人是否是同一部落的,只要查詢一下兩個人是否屬於同一祖宗就可...