对结构数组按不同成员进行排序的解决方法可以使用C++的标准库算法sort()函数和自定义的比较函数来实现。以下是一个示例代码:
#include
#include
#include
// 定义一个结构体
struct Person {
std::string name;
int age;
};
// 自定义比较函数,按照姓名升序排序
bool compareByName(const Person& p1, const Person& p2) {
return p1.name < p2.name;
}
// 自定义比较函数,按照年龄降序排序
bool compareByAge(const Person& p1, const Person& p2) {
return p1.age > p2.age;
}
int main() {
// 创建结构数组
Person people[3] = {{"Alice", 25},
{"Bob", 30},
{"Cathy", 20}};
// 按照姓名进行排序
std::sort(people, people + 3, compareByName);
// 输出排序结果
std::cout << "按照姓名排序结果:" << std::endl;
for (int i = 0; i < 3; i++) {
std::cout << people[i].name << " " << people[i].age << std::endl;
}
// 按照年龄进行排序
std::sort(people, people + 3, compareByAge);
// 输出排序结果
std::cout << "按照年龄排序结果:" << std::endl;
for (int i = 0; i < 3; i++) {
std::cout << people[i].name << " " << people[i].age << std::endl;
}
return 0;
}
在以上示例代码中,我们首先定义了一个结构体Person,包含姓名和年龄两个成员。然后我们定义了两个自定义的比较函数compareByName和compareByAge,分别用于按照姓名和年龄进行排序。最后,我们使用std::sort()函数对结构数组people进行排序,分别按照姓名和年龄进行排序,并输出排序结果。
上一篇:按不同层次聚合时测量误差