#include<bits/stdc++.h>
using namespace std;
struct s{
string m;
int f;
}a[21];
bool d(s b,s c){
if(c.f==b.f)return b.m<c.m;
return b.f>c.f;
}
int main(){
int n;
cin>>n;
for(int i=1;i<=n;i++){
cin>>a[i].m>>a[i].f;
}
sort(a+1,a+n+1,d);
for(int i=1;i<=n;i++){
cout<<a[i].m<<" "<<a[i].f<<endl;
}
return 0
}