如果有相同分数则名字字典序小的在前 可使用strcmp函数
#include<bits/stdc++.h>
using namespace std;
const int N=21;
struct score{
char name[N];
int score;
}stu[N];
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++){
cin>>stu[i].name>>stu[i].score;
}
for(int i=0;i<n-1;i++){
for(int j=0;j<n-1-i;j++){
if(stu[j].score<stu[j+1].score){
struct score temp;
temp=stu[j];
stu[j]=stu[j+1];
stu[j+1]=temp;
}
if(stu[j].score==stu[j+1].score && strcmp(stu[j].name,stu[j+1].name)>0){
struct score temp;
temp=stu[j];
stu[j]=stu[j+1];
stu[j+1]=temp;
}
}
}
for(int i=0;i<n;i++){
cout<<stu[i].name<<" "<<stu[i].score<<endl;
}
return 0;
}