#include<bits/stdc++.h>
using namespace std;
int t,n;
struct q {
string s;
int n,y,r;
} a[100000];
int main() {
cin>>n;
for(int i=1; i<=n; i++)cin>>a[i].s>>a[i].n>>a[i].y>>a[i].r;
for(int i=1;i<n;i++){
for(int j=i;j<=n;j++){
if(a[i].n>a[j].n)swap(a[i],a[j]);
else if(a[i].y>a[j].y&&a[i].n==a[j].n)swap(a[i],a[j]);
else if(a[i].r>a[j].r&&a[i].y==a[j].y)swap(a[i],a[j]);
else if(a[i].r==a[j].r)swap(a[i],a[j]);
}
}
for(int i=1; i<=n; i++)cout<<a[i].s<<"\n";
return 0;
}