#include<bits/stdc++.h>
using namespace std;
vector<int>tu[114514];
bool vis[114514];
int mem[114514];
int a,b;
int n,m;
int maxn;
void dfs(int x)
{
if(mem[x])
{
maxn=max(maxn,mem[x]);
return;
}
maxn=max(maxn,x);
for(int i=0;i<tu[x].size();i++)
{
if(vis[tu[x][i]]==0)
{
vis[x]=1;
dfs(tu[x][i]);
}
}
}
int main()
{
cin>>n>>m;
for(int i=1;i<=m;i++)
{
cin>>a>>b;
tu[a].push_back(b);
}
for(int i=1;i<=n;i++)
{
dfs(i);
mem[i]=maxn;
cout<<maxn<<" ";
maxn=0;
memset(vis,0,sizeof(vis));
}
}