#include<bits/stdc++.h>
using namespace std;
struct node
{
string name;
int y;
int m;
int d;
int num;
}oi[1005];
bool cmp(node a,node b)
{
if(a.y>b.y)
{
return 0;
}
else if(a.y<b.y)
{
return 1;
}
else
{
if(a.m>b.m)
{
return 0;
}
else if(a.m<b.m)
{
return 1;
}
else
{
if(a.d>b.d)
{
return 1;
}
else if(a.d<b.d)
{
return 0;
}
else
{
if(a.num>b.num)
{
return 1;
}
else
{
return 0;
}
}
}
}
}
int n;
int main()
{
cin>>n;
for(int i=0;i<n;i++)
{
cin>>oi[i].name>>oi[i].y>>oi[i].m>>oi[i].d;
oi[i].num=i;
}
sort(oi,oi+n,cmp);
for(int i=0;i<n;i++)
{
cout<<oi[i].name<<"\n";
}
return 0;
}