#include<bits/stdc++.h>
using namespace std;
long long n,sum,in[100010],a[100010],v[100010];
vector<long long> e[100010];
void toposort()
{
queue<int> q;
for(int i=1;i<=n;i++) if(!in[a[i]]) q.push(a[i]);
while(q.size())
{
int t=q.front();
sum++;
q.pop();
for(auto i:e[t])
{
if(!--in[i]&&v[i]) q.push(i);
}
}
}
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
{
int m,y;
cin>>a[i]>>m;
v[a[i]]=1;
for(int i=1;i<=m;i++)
{
cin>>y;
e[a[i]].push_back(y);
in[y]++;
}
}
toposort();
if(sum==n) cout<<"YES";
else cout<<n-sum;
return 0;
}