题解
#include <stdio.h>
#include <iostream>
using namespace std;
int father[300];
int a[300];
void init(int n)
{
for(int i=1;i<=n;i++)
father[i]=i;
}
int find(int x)
{
if(x!=father[x]) father[x]=find(father[x]);
return father[x];
}
void Union(int x,int y)
{
x=find(x);
y=find(y);
father[y]=x;
}
int main()
{
int n;
cin>>n;
init(n);
int x;
for(int i=1;i<=n;i++)
{
while(1)
{
cin>>x;
if(x){
Union(i,x);
}
else{
break;
}
}
}
for(int i=1;i<=n;i++)
{
a[find(i)]++;
}
int ans=0;
for(int i=1;i<=n;i++)
{
if(a[i])
ans++;
}
cout<<ans<<endl;
return 0;
}