#include<iostream>
#include<string>
using namespace std;
int main(){
int n=0;
cin>>n;
string student[10000][2];//name,sno
int grade[10000][2];//grade,index;
for(int i=0;i<n;i++)
{
cin>>student[i][0]>>student[i][1]>>grade[i][0];
grade[i][1]=i;
}
for(int i=0;i<n-1;i++)
{
for(int j=0;j<n-i-1;j++)
{
if(grade[i+1][0]>grade[i][0])
{
int t = grade[i][0];
grade[i][0]=grade[i+1][0];
grade[i+1][0]=t;
int index = grade[i][1];
grade[i][1] = grade[i+1][1];
grade[i+1][1] = index;
}
}
}
for(int i=0;i<n;i++)
{
if(i==0 || i==n-1)
cout<<student[grade[i][1]][0]<<" "<<student[grade[i][1]][1]<<endl;
}
}
用冒泡排序和索引做的。
然而答案部分正确。
没想通为什么。