m0_59715591 2022-05-30 13:54 采纳率: 60%
浏览 33
已结题

数组实现两个堆栈问题我不懂了(~_~;)

img


img


图1上画问号的地方,top不是指向最后一位的后一位嘛,那为什么top2是往后挪了一位,但是top1没有呢
图2,如果让top2等于maxsize的话,在top2插入的第一个元素岂不是就插入到maxsize去了,他最大不就是maxsize-1嘛,这不就插外面去了吗

  • 写回答

2条回答 默认 最新

  • zlebhs 2022-05-30 14:20
    关注

    图1:数组的有效索引为0到MaxSize-1,那么无效索引就是有效索引之外的,也就是说,当堆栈里无数据的时候,只要让这两个指针指向有效索引之外的地方即可,任意无效索引都可以,但是为了方便下面的计算,左侧无效索引取一般会取-1,右侧一般会取MaxSize。
    图2:结合上面的设置后,每次插入的时候,只要移动下指针在插入即可,你给的图里,他只是把这两步合为一步了而已,++(S->Top1)和--(S->Top2)。

    当然,你完全可以自己定义两个无效索引,Top1 = -1,Top2 = -2,只是这样做起来会有更多的步骤产生,没有什么必要。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 5月30日
  • 已采纳回答 5月30日
  • 赞助了问题酬金5元 5月30日
  • 修改了问题 5月30日
  • 展开全部

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测