学生类Student成员:id、yw、sx、sum。定于5位学生对象,对学生对象降序排序。编写“<”运算符函数,用于比较两个对象的大小(依据总分值决定对象的大小)。 Student s[5]=(Student(1001,80,80), Student(1002,70,70),Student(1003,90,90),Student(1004,50,50), Student(1005,60,60) ;
时间: 2023-08-08 21:04:52 浏览: 71
设计一个学生类Student(学生学号、姓名、数学、英语、计算机成绩;)
5星 · 资源好评率100%
以下是代码实现:
```cpp
#include <iostream>
#include <algorithm>
using namespace std;
class Student {
public:
int id;
int yw;
int sx;
int sum;
Student(int i, int y, int s) : id(i), yw(y), sx(s), sum(y + s) {}
bool operator<(const Student &other) const {
return sum > other.sum;
}
};
int main() {
Student s[5] = {Student(1001, 80, 80), Student(1002, 70, 70),
Student(1003, 90, 90), Student(1004, 50, 50),
Student(1005, 60, 60)};
sort(s, s + 5);
for (int i = 0; i < 5; i++) {
cout << "id: " << s[i].id << ", yw: " << s[i].yw << ", sx: " << s[i].sx << ", sum: " << s[i].sum << endl;
}
return 0;
}
```
在这个例子中,我们定义了一个 `Student` 类,它有四个成员变量:`id`、`yw`、`sx` 和 `sum`。我们在构造函数中初始化这些成员变量,`sum` 的值为 `yw` 和 `sx` 之和。
我们还重载了 `<` 运算符,用于比较两个对象的大小。我们比较的依据是 `sum` 的值,也就是总分值。
在 `main` 函数中,我们创建了一个包含 5 个学生对象的数组 `s`,并对这个数组进行降序排序。最后,我们输出排序后的结果。
阅读全文