《征服数据结构》双端栈

摘要:

1,双端栈的介绍

2,双端栈的代码实现

1,双端栈的介绍

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

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

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

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

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

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

相关推荐
山甫aa1 小时前
二叉树遍历----从零开始的数据结构
数据结构·c++·二叉树
北顾笙9802 小时前
day35-数据结构力扣
数据结构·算法·leetcode
cpp_25012 小时前
P2249 【深基13.例1】查找
数据结构·c++·算法·题解·二分·洛谷
山甫aa3 小时前
二叉树算法-----从零开始的算法
数据结构·算法
睡觉就不困鸭3 小时前
第十七天 翻转字符串里的单词
数据结构·算法·哈希算法·散列表
睡觉就不困鸭4 小时前
第十八天 有效的括号
数据结构·算法
浅念-5 小时前
分治算法专题|LeetCode高频经典题目详细题解
数据结构·c++·算法·leetcode·职场和发展·排序·分治
Irissgwe5 小时前
优选算法精讲(专题一)
数据结构·算法
睡觉就不困鸭5 小时前
第十五天 反转字符串
数据结构·算法
并不喜欢吃鱼5 小时前
从零开始C++----九【C++ 数据结构】搜索二叉树(BST)全解析:从定义到实现,一篇搞定
数据结构