这一题也是不是很难。主要是字符串处理的问题。我个人还是比较习惯于C风格的字符数组的模式。要注意使用strcmp等函数时要加上头文件cstring或者string.h。
另外自定义cmp函数中的两个小问题:
一是strcmp返回值是整型数值-1、0或1,要在函数中合理定义。
二是分数的比较中,要选择小于等于进行比较才符合题目要求顺序。
最后一个问题,我写的这个代码在pat上可以满分通过,VC6.0也可以运行,但是VS2008下会出现异常,有老铁了解咋回事嘛?
#include<iostream>
#include<string.h>
#include<vector>
#include<algorithm>
using namespace std;
struct student{
int id;
char name[9];
int grade;
};
vector<student> S;
bool cmp1(student s1,student s2){
return s1.id<s2.id;
}
bool cmp2(student s1,student s2){
int a=strcmp(s1.name,s2.name);
if(a<=0)return true;
else return false;
}
bool cmp3(student s1,student s2){
return s1.grade<=s2.grade;
}
int main(){
int N,C,i;
cin>>N>>C;
for(i=0;i<N;i++){
student temp;
cin>>temp.id>>temp.name>>temp.grade;
S.push_back(temp);
}
if(C==1)
sort(S.begin(),S.end(),cmp1);
else if(C==2)
sort(S.begin(),S.end(),cmp2);
else
sort(S.begin(),S.end(),cmp3);
for(i=0;i<N;i++)
printf("%06d %s %d\n",S[i].id,S[i].name,S[i].grade);
system("pause");
return 0;
}
关于不能在VS2008下完整运行的问题,用结构体数组代替vector之后可以解决问题,但是还是不知道为啥。。。