#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int n,m,b[100001];
vector<int> adj[100001];
void dfs(int u){
for(int i=0;i<adj[u].size();i++){
if(b[adj[u][i]]==0)cout<<adj[u][i]<<" ";
dfs(adj[u][i]);
b[adj[u][i]]=1;
}
}
void bfs(int u){
for(int i=0;i<adj[u].size();i++) {
if(b[adj[u][i]]==0)cout<<adj[u][i]<<" ";
b[adj[u][i]]=1;
}
for(int i=0;i<adj[u].size();i++) bfs(adj[u][i]);
}
int main(){
cin>>n>>m;
for(int i=0;i<m;i++){
int vv,uu;
cin>>uu>>vv;
adj[uu].push_back(vv);
}
for(int i=1;i<=n;i++){
sort(adj[i].begin(),adj[i].end());
}
cout<<1<<" ";
dfs(1);
for(int i=1;i<=n;i++) b[i]=0;
cout<<endl<<1<<" ";
bfs(1);
return 0;
}