这种初始化是用于线性栈的,也就是用一个数组来组成栈,栈顶指针值为当前栈顶元素的下标值。当有数据入栈时,会先执行栈顶指针自加。栈是一种数据结构,后进先出,即最后进入栈的数据最先弹出。c语言中没有栈这种数据类型,需要自己编程构建。栈是一种数据结构,后进先出。栈是先入后出,队列先进先出栈是先入后出。伪码入队:InQueue(elem):while(栈A不空)栈Bpush(栈Apop);栈Apush(elem);while(栈B不空)栈Apush(栈Bpop);出队outQueue():栈Apo伪码入队。
这个栈大小是编译器里的参数,你必须到你的编译环境里找到设置的地方,把上限值调大。如果你找不到这个设置菜单的话,代码改用堆空间,而不用栈空间。栈内存是一种用于存储函数局部变量、函数参数和返回值等数据的内存区域。它的大小是由编译器在编译时根据程序中局部变量的大小和数量来确定的。对于i386系列机器而言,栈是从高地址向低地址增长的。
PUSHEBPMOVEBP,ESPSUBESP0C0这几句可以看出。top =e;printf(%d,*S。top);你的e是存储在旧的top指向的地址的,但是你打印的是新的top地址存储的值,由于没有初始化,所以打印出奇怪的数字。/*在TC2和VC6下都可以顺利运行。一定要用我这个噢。有简单的输入错误检测。