题目连接L2-025-分而治之
#include<bits/stdc++.h>
using namespace std;
const int N=1e4+5;
struct node{
int x,y;
}edge[N];
int del[N];
int f[N];
int find(int x){
if(f[x]==x)return x;
return f[x]=find(f[x]);
}
void unionxy(int a,int b){
int x=find(a);
int y=find(b);
if(x!=y){
f[x]=y;
}
}
int main(){
int n,m;
cin>>n>>m;
for(int i=0;i<m;i++){
int x,y;
cin>>x>>y;
edge[i].x=x;
edge[i].y=y;
}
int k;
cin>>k;
for(int i=0;i<k;i++){
for(int t=1;t<=n;t++){
f[t]=t;
}
memset(del,0,sizeof(del));
int np;
cin>>np;
for(int j=0;j<np;j++){//先把所有的要攻打的城市标记好
int x;
cin>>x;
del[x]=1;
}
for(int j=0;j<m;j++){//并查集求出有多少个”部落“
if(del[edge[j].x]!=1&&del[edge[j].y]!=1){
unionxy(edge[j].x,edge[j].y);
}
}
int cnt=0;
for(int j=1;j<=n;j++){
if(f[j]==j)cnt++;
}
// cout<<cnt<<endl;
if(cnt==n)cout<<"YES"<<endl;//“部落”数等于所有城市数,说明一个城市就是一个部落
else cout<<"NO"<<endl;
}
return 0;
}
文章描述了一个使用C++编程实现的并查集算法,用于判断在一个有城市网络中,是否存在每个城市都独立构成一个部落的情况。通过合并节点,计算部落数量与城市总数相等,确定是否满足条件。
258





