#include<iostream>
#include<cstdio>
#include<cstring>
#define mem(a,b) memset((a),b,sizeof(a))
#define de cout<<endl<<endl<<endl
typedef long long ll;
const int N=40010;
using namespace std;
int n,m;
int head[N],ver[N],Next[N],tot;
int vis[N],match[N];
void add(int x,int y)
{
ver[++tot]=y;Next[tot]=head[x];head[x]=tot;
}
bool dfs(int x)
{
for(int i=head[x],y;i;i=Next[i])
{
if(!vis[y=ver[i]])
{
vis[y]=1;
if(!match[y]||dfs(match[y]))
{match[y]=x;return true;}
}
}
return false;
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
tot=0;
mem(head,0);
mem(match,0);
int cnt,x,y;
for(int i=1;i<=n;i++)
{
scanf("%d",&cnt);
while(cnt--)
{
scanf("%d",&x);
add(i,x);
}
}
int ans=0;
for(int i=1;i<=n;i++)
{
mem(vis,0);
if(dfs(i))
ans++;
}
printf("%d\n",ans);
}
return 0;
}