优先队列:字典序顺序
#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <vector>
#include <algorithm>
#include <queue>
#define inf 0x3f3f3f3f
using namespace std;
const int N=5e2+5;
int n,m,in[N],x,y;
vector<int> a[N];
void topo()
{
priority_queue<int,vector<int>,greater<int> > q;
for(int i=1;i<=n;i++)
if(in[i]==0)
q.push(i);
int num=0;
while(!q.empty())
{
int t=q.top();
q.pop();
num++;
printf("%d%c",t,num==n?'\n':' ');
for(int i=0;i<a[t].size();i++)
{
if(--in[a[t][i]]==0)
q.push(a[t][i]);
}
}
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
while(cin >> n >> m)
{
memset(in,0,sizeof(in));
for(int i=1;i<=n;i++)
a[i].clear();
while(m--)
{
cin >> x >> y;
in[y]++;
a[x].push_back(y);
}
topo();
}
return 0;
}