/**
有向图才会有拓扑序列
所有的边都是从前指向后的
有向无环图被称为拓扑图
有向图两个概念: 入度 + 出度
所有入度为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++;
}
void topsort()
{
int num =0;
queue<int> q;
for(int i=1; i<=m; i++)
{
if(!d[i])
{
//cout<<"我的2呢??";
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);
}
}
}
int main()
{
cin>>m;
memset(h,-1,sizeof h);
for(int i=1; i<=m; i++)
{
int x;
while(cin>>x)
{
if(!x)
break;
add(i,x);
d[x] ++;
}
}
topsort();
for(int i=0;i<dx;i++)
cout<<ans[i]<<" ";
return 0;
}