堆栈(stack)的四种类型

堆栈严格来说应该叫做栈(stack),先入后出

四种类型:满增栈、满减栈、空增栈、空减栈。

 

满、空栈区别:根据当前指针所在位置是否有东西。

满栈(full stack):栈指针指向最后压入栈的数据,数据入栈时,sp先减一(或加一)再入栈。

空栈(empty stack):栈指针指向下一个将要放入数据的位置,数据入栈时,先入栈sp再减一(或加一)。

 

增、减栈区别:根据堆栈的生成方向不同。

递增堆栈(ascending stack):堆栈由低地址向高地址生长。

递减堆栈(secending stack):堆栈由高地址向低地址生长。

 

总结:

 

满栈进栈是先移动指针再存;

满栈出栈是先出数据再移动指针;

空栈进栈先存再移动指针;

空栈出栈先移动指针再取数据。

 

ARM处理器核对于两种生长方式的堆栈均支持。

 

 

 

 

 

### 堆栈数据结构的概念 堆栈Stack)是一种特殊的线性表,其操作遵循后进先出(LIFO, Last In First Out)的原则。这意味着最后被压入堆栈的元素会最先被弹出[^1]。 ```python class Stack: def __init__(self): self.items = [] def push(self, item): """向堆栈中添加一个新元素""" self.items.append(item) def pop(self): """移除并返回堆栈顶部的元素""" if not self.is_empty(): return self.items.pop() def peek(self): """查看堆栈顶部的元素而不移除它""" if not self.is_empty(): return self.items[-1] def is_empty(self): """判断堆栈是否为空""" return len(self.items) == 0 def size(self): """返回堆栈中的元素数量""" return len(self.items) ``` ### 特点 堆栈的主要特点是它的操作仅限于一端——即堆栈顶。所有的插入(称为“压栈”或“push”)和删除(称为“弹栈”或“pop”)都发生在这一端。这种特性使得堆栈非常适合用于解决某些特定类型的问题[^3]。 - **单一入口/出口**:所有元素的操作都在同一端完成。 - **顺序访问**:无法随机访问中间的某个元素;只能按照 LIFO 的原则依次访问。 - **简单高效**:由于只在一端操作,因此时间复杂度较低,通常为 O(1)[^2]。 ### 应用场景 #### 1. 函数调用管理 在计算机运行过程中,每当执行到函数调用时,都会将当前状态保存至堆栈上以便后续恢复。这包括局部变量、参数以及返回地址等信息。 #### 2. 表达式求值与转换 堆栈常用来解析算术表达式或将中缀表示法转化为前缀或后缀形式,在编译器设计中有广泛应用。 #### 3. 回溯算法支持 许多搜索问题可以通过回溯方法解决,而这些过程往往依赖于显式的或者隐含使用的堆栈机制来记录路径节点的状态变化情况[^2]。 #### 4. 内存分配控制 操作系统利用硬件级别的堆栈来进行动态内存分配,尤其是在 C/C++ 等语言环境中非常普遍。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值