设计一个学生类(Student),包括私有数据成员:学号(int型),姓名,成绩(int型),函数成员根据需要定义。 设计一个数组类模板(Array),形式大致如下: class Array{ private: int size; T *element; public: ~Array();//析构函数 operator>>//重载输入运算符 operator<<//重载输出运算符 void sort();//对数组内数据排序 }; Main函数内实现大致如下(以int型为例)
时间: 2024-03-13 22:45:04 浏览: 61
好的,我理解了你的问题。以下是对你的问题的回答:
首先,这是一个简单的学生类的实现:
```cpp
class Student {
private:
int id;
std::string name;
int score;
public:
Student(int id, std::string name, int score) : id(id), name(name), score(score) {}
int getId() const { return id; }
std::string getName() const { return name; }
int getScore() const { return score; }
void setScore(int score) { this->score = score; }
};
```
接下来是一个数组类模板的实现:
```cpp
template<typename T>
class Array {
private:
int size;
T *element;
public:
Array(int size) : size(size), element(new T[size]) {}
~Array() { delete[] element; }
friend std::istream& operator>>(std::istream& in, Array<T>& arr) {
for (int i = 0; i < arr.size; ++i) {
in >> arr.element[i];
}
return in;
}
friend std::ostream& operator<<(std::ostream& out, const Array<T>& arr) {
for (int i = 0; i < arr.size; ++i) {
out << arr.element[i] << " ";
}
out << std::endl;
return out;
}
void sort() {
std::sort(element, element + size);
}
};
```
最后是主函数的实现:
```cpp
int main() {
int n;
std::cin >> n;
Array<int> arr(n);
std::cin >> arr;
std::cout << "Before sorting: " << arr;
arr.sort();
std::cout << "After sorting: " << arr;
return 0;
}
```
这个程序将首先从标准输入中读取一个整数n,然后创建一个大小为n的Array<int>对象。接下来,它将从标准输入中读取n个整数,并将它们存储在数组中。然后,它将输出未排序的数组,排序数组,然后输出排序后的数组。
阅读全文