在数据结构课程中,C++的Array类可以用来实现各种不同的数据结构,比如栈、队列、堆等。通过自定义Array类,可以更好地理解数据结构的原理和实现方式。
下面是一个简单的示例,演示如何使用Array类来实现一个栈:
#include <iostream>
template <typename T>
class Array {
private:
T* data;
int size;
int capacity;
public:
Array(int capacity) {
this->capacity = capacity;
this->size = 0;
this->data = new T[capacity];
}
void push(T element) {
if (size == capacity) {
std::cout << "Stack is full, cannot push more elements" << std::endl;
return;
}
data[size++] = element;
}
T pop() {
if (size == 0) {
std::cout << "Stack is empty, cannot pop element" << std::endl;
exit(1);
}
return data[--size];
}
T top() {
if (size == 0) {
std::cout << "Stack is empty, no element at the top" << std::endl;
exit(1);
}
return data[size-1];
}
bool isEmpty() {
return size == 0;
}
};
int main() {
Array<int> stack(5);
stack.push(1);
stack.push(2);
stack.push(3);
std::cout << "Top element: " << stack.top() << std::endl;
stack.pop();
std::cout << "Top element after pop: " << stack.top() << std::endl;
return 0;
}
通过这个示例,可以看到如何使用Array类来实现一个简单的栈。在数据结构课程中,可以通过自定义Array类来实践各种不同的数据结构,加深对数据结构的理解和掌握。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。