#include <bits/stdc++.h>
using namespace std;
struct node{
string name;
int chj;
}a[25];
bool cmp(node x,node y){
if(x.chj!=y.chj) return x.chj>y.chj;
return x.name<y.name;
}
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++) cin>>a[i].name>>a[i].chj;
sort(a,a+n,cmp);
for(int i=0;i<n;i++) cout<<a[i].name<<" "<<a[i].chj<<endl;
return 0;
}