思路:
其实这道题就是用并查集来寻找节点,然后来判断子图是否一样,一样就继续,不一样就退出。
代码如下:
#include<bits/stdc++.h>
using namespace std;
int a[1005][1005],pre[1005],toto[1005];
int Find(int x){
if(pre[x]!=x){
pre[x]=Find(pre[x]);
}
return pre[x];
}
int main(){
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++){
pre[i]=i;
toto[i]=1;
}
for(int i=1;i<=n;i++){
scanf("%d",&a[i][0]);
for(int j=1;j<=a[i][0];j++){
scanf("%d",&a[i][j]);
}
}
for(int k=n;k>=1;k--){
for(int i=1;i<=a[k][0];i++){
if(a[k][i]<=k)
continue;
int x=Find(k);
int y=Find(a[k][i]);
if(x!=y){
pre[y]=x;
toto[x]+=toto[y];
if(toto[x]>n-n/2 ){
cout<<k;
return 0;
}
}
}
}
return 0;
}