初始化栈的代码_栈——顺序栈

ec382cf3e2e3a1d5626d49b871518678.png

点击图片上方蓝字字体 " 算法简堂 "即可订阅 栈——顺序栈

1 栈

f926f43a289175a9e03bc52dcd54db4d.png

大家都有将物品收纳进盒子里的经历,也一定有先放进去的物品需要在最后才能取出的认识。对栈的操作就如同使用这个盒子。栈是一种只能在一端进行插入与删除操作的线性表。此外,还有以下相关概念:

①允许进行插入、删除操作的一端称为栈顶。

②表的另一端称为栈底。

③当栈中没有数据元素时,称为空栈。

④栈的插入操作通常称为进栈或入栈。

⑤栈的删除操作通常称为退栈或出栈。

栈的主要特点是“后进先出”,即后进栈的元素先出栈。栈也称为后进先出表。我们知道存储结构主要有顺序存储结构、链式存储结构、索引存储结构和哈希存储结构,接下来我们就详细了解一下使用顺序存储结构实现的顺序栈。

2 顺序栈

(1)认识顺序栈

假设栈的的元素都具有同一数据类型ElemType,则可用下列方式来定义顺序栈类型SqStack:

e098c62b89e1a7e973952c3afef90573.png参照顺序表,可以画出顺序栈的示意图。

1c752ba47f953e0d29f54d755ed9db60.png

说明:①约定top总是指向栈顶元素,初始值为-1(后边部分动画和图片为说明问题将-1画在了物理位序下,实则不属于);

②当top=MaxSize-1时不能再进栈,即栈满;

③进栈时top增1,出栈时top减1。

如此,我们可以得出以下四方面内容:

①栈空条件:top=-1;

②e进栈操作:top++,并将e放在top处;

③栈满条件:top=MaxSize-1;

④退栈操作:从top处取出元素e,且top--。

3b7fcc2d13afc63cfdb920c368192454.png

栈主要有初始化栈、销毁栈、判断栈是否为空、进栈、出栈、取栈顶元素等基本运算,限于篇幅,我们仅讲解初始化栈、进栈、出栈、取栈顶元素(全部详细算法关注公众号后回复004获取)。

(2)初始化栈

操作:建立一个新的空栈s,实际上是将栈顶指针指向-1即可。

总结:s为栈指针,top为s所指栈的栈顶指针。

主要代码:

920285d497230b818d0fefba06042149.png

(3)进栈

操作:在栈不满的条件下,先将栈指针增1,然后在该位置上插入元素e。

4893781312135caee49765a65d841627.gif

主要代码:

597846e3f6a54d5cbfe6e940c3ea8f2d.png

(4)出栈

操作:在栈不为空的条件下,先将栈顶元素赋给e,然后将栈指针减1。

e976dda568cf996fb940f2353cf824a0.gif

主要代码:

641c9edcf4eaa3eca4ff528384645e9d.png

(5)取栈顶元素

操作:在栈不为空的条件下,将栈顶元素赋给e。

主要代码:

d0c2324495ff361e64ccd0a58bcd91c9.png

END

985a0c34a8e5c0e64ac46e8a01d4103f.png长按 关注轻松学习 f3cf53461bcbd439f908c46b8c6295b0.gif 给个“赞”和“在看”,是对简堂最大的支持!
  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值