码迷,mamicode.com
首页 > 编程语言 > 详细

九度1023:EXCEL排序

时间:2015-01-03 22:29:32      阅读:446      评论:0      收藏:0      [点我收藏+]

标签:

http://ac.jobdu.com/problem.php?pid=1023

分别写cmp函数即可。

#include<cstdio>

#include<cstring>
#include<algorithm>
using namespace std;
struct E{
char number[10];
char name[10];
int score;
}buf[100000+10];


bool cmp1(E a,E b){
int tmp=strcmp(a.number,b.number);
if(tmp!=0) return tmp<0;
}


bool cmp2(E a,E b){
int tmp1=strcmp(a.name,b.name);
if(tmp1!=0) return tmp1<0;
else {
int tmp2=strcmp(a.number,b.number);
if(tmp2!=0) return tmp2<0;
}
}


bool cmp3(E a,E b){
if(a.score!=b.score) return a.score<b.score;
else {
int tmp=strcmp(a.number,b.number);
if(tmp!=0) return tmp<0;
}
}


int main()
{
int n,m,i;
int count=1;
while(scanf("%d %d",&n,&m)!=EOF)
{
if(n==0&&m==0) break;
for(i=0;i<n;i++)
{
scanf("%s %s %d",buf[i].number,buf[i].name,&buf[i].score);
}
if(m==1)
{
sort(buf,buf+n,cmp1);
printf("Case %d:\n",count++);
for(i=0;i<n;i++)
{
printf("%s %s %d\n",buf[i].number,buf[i].name,buf[i].score);
}
}
if(m==2)
{
sort(buf,buf+n,cmp2);
printf("Case %d:\n",count++);
for(i=0;i<n;i++)
{
printf("%s %s %d\n",buf[i].number,buf[i].name,buf[i].score);
}
}
if(m==3)
{
sort(buf,buf+n,cmp3);
printf("Case %d:\n",count++);
for(i=0;i<n;i++)
{
printf("%s %s %d\n",buf[i].number,buf[i].name,buf[i].score);
}
}


}
return 0;
}

九度1023:EXCEL排序

标签:

原文地址:http://blog.csdn.net/lanjiangzhou/article/details/42368817

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!