《征服数据结构》双端栈

摘要:

1,双端栈的介绍

2,双端栈的代码实现

1,双端栈的介绍

双端栈主要利用了"栈底位置不变,栈顶位置动态变化" 的特点,可以让两个栈共享一块存储空间。在前面我们讲到用数组实现栈的时候,如果把数组的两端都当做栈底,就可以构造出两个栈。

双端栈是指将一个线性表的两端当做栈底分别进行入栈和出栈操作,如下图所示:

1,当 lTop==-1 时 表示左端栈为空,左端栈的有效元素个数为 lTop + 1 。

2,当 rTop==data.length 时,表示右端栈为空,右端栈的有效元素个数为 data.length - rTop 。

3,当 lTop+1==rTop 时,表示双端栈满 。

双端栈的常见函数相比普通栈的函数要多,因为双端栈要操作左右两个栈。

相关推荐
fei_sun3 分钟前
【总结】【数据结构】树、二叉树、森林转化
数据结构
豆沙沙包?22 分钟前
2025年--Lc298-1019. 链表中的下一个更大节点(栈)--java版
java·数据结构·链表
罗湖老棍子35 分钟前
二维vector完全指南1:从定义到增删改查
数据结构·c++·算法·stl
再卷也是菜35 分钟前
C++篇(22)LRU Cache
数据结构·c++·算法
程序猿多布1 小时前
数据结构 之 栈和队列
数据结构··队列
zs宝来了1 小时前
HOT100系列-堆类型题
数据结构·算法·排序算法
报错小能手2 小时前
数据结构 带头节点的链表
数据结构·链表
sin_hielo2 小时前
leetcode 1590
数据结构·算法·leetcode
吃着火锅x唱着歌2 小时前
LeetCode 2748.美丽下标对的数目
数据结构·算法·leetcode
自然语2 小时前
人工智能之数字生命-学习的过程
数据结构·人工智能·深度学习·学习·算法