#include<iostream>
#include<algorithm>
#include<string>
#include<string.h>
using namespace std;
struct student
{
char id[10];
char name[10];
int grade;
}stu[100050];
bool cmp1(student x,student y)
{
return(strcmp(x.id,y.id)<0);
}
bool cmp2(student x,student y)
{
if (strcmp(x.name,y.name)!=0){return (strcmp(x.name,y.name)<0);}
else {return(strcmp(x.id,y.id)<0);}
}
bool cmp3(student x,student y)
{
if (x.grade!=y.grade){return (x.grade<y.grade);}
else {return(strcmp(x.id,y.id)<0);}
}
int main()
{
int n,c;
cin>>n>>c;
for (int i=0;i<n;i++)
{
cin>>stu[i].id>>stu[i].name>>stu[i].grade;
}
if (c==1)
{
sort(stu,stu+n,cmp1);
for(int i=0;i<n;i++)
{
printf("%s %s %d\n",stu[i].id,stu[i].name,stu[i].grade);
}
}
if (c==2)
{
sort(stu,stu+n,cmp2);
for(int i=0;i<n;i++)
{
printf("%s %s %d\n",stu[i].id,stu[i].name,stu[i].grade);
}
}
if (c==3)
{
sort(stu,stu+n,cmp3);
for(int i=0;i<n;i++)
{
printf("%s %s %d\n",stu[i].id,stu[i].name,stu[i].grade);
}
}
system("pause");
return 0;
1.不用c的输出格式最后一个点会超时
#include<algorithm>
#include<string>
#include<string.h>
using namespace std;
struct student
{
char id[10];
char name[10];
int grade;
}stu[100050];
bool cmp1(student x,student y)
{
return(strcmp(x.id,y.id)<0);
}
bool cmp2(student x,student y)
{
if (strcmp(x.name,y.name)!=0){return (strcmp(x.name,y.name)<0);}
else {return(strcmp(x.id,y.id)<0);}
}
bool cmp3(student x,student y)
{
if (x.grade!=y.grade){return (x.grade<y.grade);}
else {return(strcmp(x.id,y.id)<0);}
}
int main()
{
int n,c;
cin>>n>>c;
for (int i=0;i<n;i++)
{
cin>>stu[i].id>>stu[i].name>>stu[i].grade;
}
if (c==1)
{
sort(stu,stu+n,cmp1);
for(int i=0;i<n;i++)
{
printf("%s %s %d\n",stu[i].id,stu[i].name,stu[i].grade);
}
}
if (c==2)
{
sort(stu,stu+n,cmp2);
for(int i=0;i<n;i++)
{
printf("%s %s %d\n",stu[i].id,stu[i].name,stu[i].grade);
}
}
if (c==3)
{
sort(stu,stu+n,cmp3);
for(int i=0;i<n;i++)
{
printf("%s %s %d\n",stu[i].id,stu[i].name,stu[i].grade);
}
}
system("pause");
return 0;
}