m0_65215277 2022-10-21 11:52 采纳率: 57.1%
浏览 122
已结题

顺序栈出栈如何删除栈顶元素?

书上的代码:


int Pop(SqStack &S,SElemType&e)
{
    if(S.top==S.base)  return 0;
    e=*--S.top;    //--S.top之后不是只把指针移动了吗?原栈顶的元素应该还在内存中吧,为什么不进行删除操作呢?
    return 1;
}
  • 写回答

1条回答 默认 最新

  • zlebhs 2022-10-21 13:27
    关注

    指针移动了,不就是相当于删除了吗?栈无非就是使用数组或者链表来实现,从数组来看,只要你定义了数组长度,就必定会占用内存,跟你里面有没有值,值是多少没关系,因此只需要移动指针,就可以很简单的做到删除,不需要多次一举的去“删除其中的元素”。如果是链表实现的,那么就需要真正的删除。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

    报告相同问题?

    问题事件

    • 系统已结题 11月25日
    • 已采纳回答 11月17日
    • 创建了问题 10月21日

    悬赏问题

    • ¥15 MYSQL 订单的商品明细重复计算问题
    • ¥15 微信实时共享位置修改
    • ¥100 TG的session协议号转成直登号号后客户端登录几分钟后自动退出设备
    • ¥30 共模反馈回路的小信号增益
    • ¥15 arduino ssd1306函数与tone函数放歌代码不兼容问题
    • ¥70 0.96版本hbase的row_key里含有双引号,无法deleteall
    • ¥40 Ida Pro增加插件出现问题
    • ¥15 诊断性META分析合并效能的检验
    • ¥15 请问abb根据色块判断奇偶数并根据批次号放入仓储
    • ¥66 开发PC客户端一定也要开发上位机吗?