《征服数据结构》双端栈

摘要:

1,双端栈的介绍

2,双端栈的代码实现

1,双端栈的介绍

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

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

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

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

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

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

相关推荐
fashion 道格3 小时前
用 C 语言玩转归并排序:递归实现的深度解析
数据结构·算法·排序算法
j_xxx404_4 小时前
C++:继承(概念及定义|作用域|基类与派生类转换|默认成员函数|与友元、静态成员关系|多继承|组合)
数据结构·c++
码银4 小时前
【数据结构】 栈和队列
数据结构
Freedom_my5 小时前
插入排序算法
数据结构·算法·排序算法
952365 小时前
排序-算法
数据结构·算法·排序算法
WongKyunban5 小时前
插入排序的原理和示例
数据结构·算法·排序算法
聪明绝顶的小Yya6 小时前
数据结构万字解读
数据结构
迈巴赫车主7 小时前
蓝桥杯 20541魔法科考试
java·数据结构·算法·蓝桥杯
帧栈10 小时前
并发编程原理与实战(三十八)高并发利器ConcurrentHashMap 数据结构与核心API深度剖析
数据结构
cpp_250111 小时前
P1765 手机
数据结构·c++·算法·题解·洛谷