#include<cstdlib>
#include<string>
#include<algorithm>
struct student{
std::string name;
int id;
int age;
};
bool compareId(student & s1, student & s2){
return s1.id < s2.id;
}
bool compareAge(student & s1, student & s2){
return s1.age < s2.age;
}
void print(student arr[],int length){
if (arr == nullptr || length <= 0){
return;
}
for (int i = 0; i < length; ++i)
printf("name: %-10s, id : %-d, age: %-d\n",arr[i].name.c_str(), arr[i].id, arr[i].age);
printf("-----------------\n");
}
int main(){
student arr[] = {
{ "xiao ming",1,21 },
{ "xiao hua",3,18 },
{ "xiao liang",3,18 },
{ "xiao li",4,20 },
{ "xiao bai",5,18 }
};
printf("original arr:\n");
print(arr, 5);
std::sort(arr, arr + 5, compareId);
print(arr, 5);
std::sort(arr, arr + 5, compareAge);
printf("sorted arr:\n");
print(arr, 5);
system("pause");
return 0;
}
比较器C++版
最新推荐文章于 2024-02-05 21:46:21 发布