全部问题 > 当前问题

栈顶top=m,则有一个元素,再退一个栈,为什么会变成m加1个元素


刘攀 2017-9-4 20:29:52

共 2 个回答

晓晓 2017-9-7 08:47:36

退一个就多了一个元素呀

王文涛 2017-11-25 17:24:17

并不是元素,是栈底指针变成m+1


问题来自:
设栈的存储空间为S(1:m),初始状态为top=m+1。经过一系列入栈与退栈操作后,top=m。现又在栈中退出一个元素后,栈顶指针top值为( )
A. m+1
B. 0
C. m-1
D. 产生栈空错误
答案:A
解析:栈的顺序存储空间为S(1: m),初始状态top=m+1,所以这个栈是m在栈底,1是开口向上的。所以经过一系列入栈与退栈操作后,top=m,则有1个元素,若现在又退出一个元素,那么栈顶指针下移一位,回到m+1的位置。因此这题选择A。