#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <vector>
#include <algorithm>
#include <queue>
#define inf 0x3f3f3f3f
using namespace std;
const int N=1e2+5;
int n,m,in[N],x,y;
vector<int> a[N];
void topo()
{
queue<int> q;
for(int i=0;i<n;i++)
if(in[i]==0)
q.push(i);
int num=0;
while(!q.empty())
{
int t=q.front();
q.pop();
num++;
for(int i=0;i<a[t].size();i++)
{
if(--in[a[t][i]]==0)
q.push(a[t][i]);
}
}
if(num<n)
printf("NO\n");
else
printf("YES\n");
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
while(cin >> n >> m,n||m)
{
memset(in,0,sizeof(in));
for(int i=0;i<n;i++)
a[i].clear();
while(m--)
{
cin >> x >> y;
in[y]++;
a[x].push_back(y);
}
topo();
}
return 0;
}
Legal or Not HDU - 3342
最新推荐文章于 2020-07-15 16:57:11 发布