/**
有向图才会有拓扑序列
所有的边都是从前指向后的
有向无环图被称为拓扑图
有向图两个概念: 入度 + 出度
所有入度为0的点 都可以当做起点
queu <- 所有入度为0的点
while queue 不空
{
t<-队头
枚举t的所有出边 t->j
删除t->j
d[j]– J的入度减一
if d[j]=0 queu <- j
}
**/
include [HTML_REMOVED]
using namespace std;
const int N =1e5+10;
int n,m;
int h[N],e[N],ne[N],idx;
int d[N];
int ans[N];
int dx ;
void add(int a,int b)
{
e[idx] = b;
ne[idx]= h[a];
h[a]= idx++;
}
bool topsort()
{
int num =0;
queue<int> q;
for(int i=1;i<=n;i++)
{
if(!d[i])
q.push(i);
}
while(!q.empty())
{
num++;
int t=q.front();
ans[dx++] = t;
q.pop();
for(int i=h[t];i!=-1;i=ne[i])
{
int j =e[i];
d[j] --;
if(d[j] ==0)
q.push(j);
}
}
if(num ==n)
return true;
else
return false;
}
using namespace std;
int main()
{
cin>>n>>m;
memset(h,-1,sizeof h);
for(int i=0;i<m;i++)
{
int a,b;
cin>>a>>b;
add(a,b);
d[b] ++;
}
if(topsort())
{
for(int i=0;i<n;i++)
{
cout<<ans[i]<< " " ;
}
cout<<endl;
}
else
puts("-1");
return 0;
}