顺序栈的全部基本操作的实现(初始化、销毁、清空、判断栈是否为空、求栈长、进栈、出栈、取栈顶元素、遍历等)。并创立菜单
时间: 2024-11-27 21:17:49 浏览: 40
顺序栈是一种基于数组实现的数据结构,它按照后进先出(LIFO,Last In First Out)的原则进行数据存储。以下是顺序栈的基本操作及其实现:
1. **初始化(创建栈)**:
```cpp
Stack<int> stack; // 使用C++风格的模板,创建一个整型顺序栈
```
2. **销毁(释放内存)**:
由于栈通常是自动管理内存的,我们不需要显式地销毁。当栈不再使用时,其占用的空间会在程序结束时自动回收。
3. **清空(pop_all)**:
```cpp
while (!stack.isEmpty()) {
stack.pop(); // 依次删除所有元素
}
```
4. **判断栈是否为空**:
```cpp
bool isEmpty = stack.isEmpty(); // 返回true表示为空
```
5. **求栈长**:
```cpp
int size = stack.getSize(); // 如果没有直接的方法,可能需要记录插入元素的数量
```
6. **进栈(push)**:
```cpp
stack.push(5); // 将整数5压入栈顶
```
7. **出栈(pop)**:
```cpp
int topElement = stack.pop(); // 删除并返回栈顶元素,如果没有元素则抛异常
```
8. **取栈顶元素(peek)**:
```cpp
int peek = stack.peek(); // 返回栈顶元素,但不删除
```
9. **遍历(打印所有元素)**:
```cpp
for (int i = 0; i < size; ++i) {
cout << stack.top() << " ";
stack.pop(); // 为了实际查看每个元素,这里假设pop会改变栈顶
}
```
**顺序栈菜单**:
1. 初始化新栈
2. 检查栈是否为空
3. 查看栈顶元素
4. 入栈元素
5. 出栈元素
6. 获取栈长度
7. 清空栈
8. 遍历栈内元素
9. 关闭栈
阅读全文