设计一个学生类(Student),包括私有数据成员:学号(int型),姓名,成绩(int型),函数成员根据需要定义。 设计一个数组类模板(Array),形式大致如下: class Array{ private: int size; T *element; public: ~Array();//析构函数 operator>>//重载输入运算符 operator<<//重载输出运算符 void sort();//对数组内数据排序 }; Main函数内实现大致如下(以int型为例): main(){ int num;//每种数据类型测试数据的个数 cin>>num; Array<int> array_int(num);//初始化数组 cin>>array_int;//调用重载输入运算符输入数据 array_int.sort();//按要求对数组内数据排序 cout<<array_int<<endl;//调用重载输出运算符输出数据 } 要求重载输入和输出运算符,实现对数组内数据的输入和输出,并设计成员函数sort(),当数组内数据是int,double型时,按照从小到大的顺序对数组数据进行排序并输出结果;当数组内数据是char型时,按照ASCII码从小到大的顺序排序并输出结果;当数组内数据为Student类型时,按照成绩(没有重复值)从小到大的顺序,输出排序后的学生学号。
时间: 2024-03-10 16:47:09 浏览: 138
好的,按照你的要求,我来设计学生类(Student)和数组类模板(Array)。
```cpp
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
// 学生类
class Student {
private:
int id; // 学号
string name; // 姓名
int score; // 成绩
public:
Student() {} // 默认构造函数
Student(int i, string n, int s) : id(i), name(n), score(s) {} // 带参构造函数
// 获取学生信息
int getId() { return id; }
string getName() { return name; }
int getScore() { return score; }
// 重载小于运算符,用于排序
bool operator < (const Student& other) const {
return score < other.score;
}
};
// 数组类模板
template <typename T>
class Array {
private:
int size; // 数组大小
T *element; // 数组元素
public:
Array(int s) : size(s) { element = new T[size]; } // 带参构造函数
~Array() { delete [] element; } // 析构函数
// 重载输入运算符
friend istream& operator >> (istream& in, Array<T>& arr) {
for (int i = 0; i < arr.size; i++) {
in >> arr.element[i];
}
return in;
}
// 重载输出运算符
friend ostream& operator << (ostream& out, Array<T>& arr) {
for (int i = 0; i < arr.size; i++) {
out << arr.element[i] << " ";
}
out << endl;
return out;
}
// 对数组内数据排序
void sort() {
if (typeid(T) == typeid(int) || typeid(T) == typeid(double)) {
std::sort(element, element + size);
} else if (typeid(T) == typeid(char)) {
std::sort(element, element + size, [](char a, char b) {
return a < b;
});
} else if (typeid(T) == typeid(Student)) {
std::sort(element, element + size);
}
}
};
int main() {
int num;
cin >> num;
// 测试 int 类型数组
Array<int> array_int(num);
cin >> array_int;
array_int.sort();
cout << array_int;
// 测试 double 类型数组
Array<double> array_double(num);
cin >> array_double;
array_double.sort();
cout << array_double;
// 测试 char 类型数组
Array<char> array_char(num);
cin >> array_char;
array_char.sort();
cout << array_char;
// 测试 Student 类型数组
Array<Student> array_student(num);
for (int i = 0; i < num; i++) {
int id, score;
string name;
cin >> id >> name >> score;
array_student[i] = Student(id, name, score);
}
array_student.sort();
for (int i = 0; i < num; i++) {
cout << array_student[i].getId() << " ";
}
cout << endl;
return 0;
}
```
在上述代码中,我们首先定义了一个学生类(Student),包括了学号、姓名、成绩三个私有数据成员和一个带参构造函数,以及获取学生信息的三个成员函数。为了排序方便,我们在学生类中重载了小于运算符。
然后我们定义了一个数组类模板(Array),包括了数组大小和数组元素两个私有数据成员和带参构造函数、析构函数、重载输入运算符、重载输出运算符和对数组内数据排序的成员函数。在重载输入和输出运算符中,我们使用了友元函数,方便实现对数组的输入和输出。在对数组内数据排序的成员函数中,我们通过判断T的类型来实现不同类型的排序,其中 int 和 double 类型按照从小到大的顺序排序,char 类型按照 ASCII 码从小到大的顺序排序,而 Student 类型则按照成绩从小到大的顺序排序。
最后在 main 函数中,我们按照题目要求分别测试了 int、double、char 和 Student 四种类型的数组。
阅读全文