思维导图
栈
#include <iostream>using namespace std;template <typename T>
class Stack
{
private:static const size_t MAX = 100; // 定义固定容量T data[MAX]; // 存储栈元素的数组size_t len; // 当前栈的大小public:// 构造函数Stack() : len(0) {}// top 操作T& top(){return data[len - 1]; // 返回栈顶元素}// empty 操作bool empty() const{return len == 0;}// size 操作size_t size() const{return len;}// push 操作void push(T value){if (len < MAX){data[len++] = value;}else{cout << "错误" << endl; // 栈溢出处理}}// pop 操作void pop(){if (!empty()){--len;}else{cout << "错误" << endl; // 栈下溢出处理}}
};// 示例使用
int main()
{Stack<int> s;s.push(1);s.push(2);s.push(3);cout << "栈顶: " << s.top() << endl; // 输出 3cout << "栈大小: " << s.size() << endl; // 输出 3s.pop();cout << "pop后的栈顶: " << s.top() << endl; // 输出 2return 0;
}
队列
#include <iostream>using namespace std;template <typename T>
class Queue
{
private:static const size_t max = 100; // 定义固定容量T data[max]; // 存储队列元素的数组size_t top; // 队首索引size_t tail; // 队尾索引size_t len; // 当前队列的大小public:// 构造函数Queue() : top(0), tail(0), len(0) {}// front 操作T& front(){return data[top]; // 返回队首元素}// back 操作T& back(){return data[(tail - 1 + max) % max]; // 返回队尾元素}// empty 操作bool empty() const{return len == 0;}// size 操作size_t size() const{return len;}// push 操作void push(T value){if (len < max){data[tail] = value;tail = (tail + 1) % max;++len;}else{cout << "错误" << endl; // 队列溢出处理}}// pop 操作void pop(){if (!empty()){top = (top + 1) % max;--len;}else{cout << "错误" << endl; // 队列下溢出处理}}
};// 示例使用
int main()
{Queue<int> q;q.push(1);q.push(2);q.push(3);cout << "队首: " << q.front() << endl; // 输出 1cout << "队尾: " << q.back() << endl; // 输出 3cout << "队列的长度: " << q.size() << endl; // 输出 3q.pop();cout << "pop后的队首: " << q.front() << endl; // 输出 2return 0;
}