77问答网
所有问题
关于堆栈的问题:在c语言中,由于把a变量压入堆栈,top弹出堆栈的时候,弹出来的值是给谁
如果这个值不是返回给a的话,那堆栈的意义在哪里?请高手解释下
举报该问题
推荐答案 2011-12-23
1. 首先一点你要明白的是,栈中保存的是值,也就是a入栈,是把a的值放到栈中,栈不会记得这个值是a的。
2. C语言中,我们使用栈从来都只是为了保存一个值而已,并不关心这个值是谁的。你想想看,你使用栈的过程中有去关心过每个入栈的值的来源吗?栈只是简单的数据堆放的仓库而已,不过是进进出出要按照顺序罢了。
3. 栈弹出时,弹出一个值,这个值要赋给谁,由你自己决定,但是他绝对不会自动赋给a。你可以仍旧赋给a,或者赋给b,c,d等等,比如像 函数Pop(Stack s, int a)中a就是你自己指定了。
4. 弹出栈的时候,要注意的一点是,你要想把原来压入栈中的值重新赋回给a,那么很重要的一点是,你要确定这个弹出的值确实是a的,这就要求你要记住入栈,出栈的顺序。这个你应该知道吧。
5. 上面说的几点都是我从要想要得到的答案方面回答的,但实际中要要保存a的值,肯定是在声明一个变量保存,int b = a; 不就可以了。不会有人真的去构造一个栈来保存值。真正需要用栈来保存值是在汇编语言中(不知道你学过没有),寄存器只有有限的10几个,只能靠栈来保存一些值,不像C中变量可以声明无数个,可能说过头了,希望你可以明白。
温馨提示:答案为网友推荐,仅供参考
当前网址:
http://77.wendadaohang.com/zd/8INppWpN3.html
其他回答
第1个回答 2011-12-23
没明白你的意思,首先你要明白堆中的空间并不像栈是有秩序的.堆是一大堆不连续的空间,所以根本不存在压不压入堆的说法.还有,堆栈不能连续说,堆就是堆,栈就是栈.堆栈是两者的总称.
相似回答
栈的
操作原则是什么?
答:
堆栈使用两种基本操作:推入(压栈,push)和弹出(
弹栈,
pop):1、推入:将资料放入堆栈顶端,堆栈顶端移到新放入的资料。2、
弹出:
将堆栈顶端资料移除,堆栈顶端移到移除后的下一笔资料。特点
堆栈的
基本特点:1、先入后出,后入先出。2、除头尾节点之外,每个元素有一个前驱,一个后继。软件堆栈...
c语言栈的top是
什么意思?
答:
一般情况下,初始设置top=-1,栈空条件:top==-1,栈满条件:top==length-1,栈长top+1
,top
==N(即length)表示栈空,故栈长top-1,栈满条件:top==N-N=0。因为用一个长度为n的数组顺序储存一个栈然而数组是从0~n-1栈空为top==n那么栈满为top==1。t数组长度固定为...
关于
单片机在调用子程序
时,
进行了怎样的
堆栈
操作
答:
取决于子程序的类型和编程方式。有些特殊类型的子程序是需要入
栈的
,若采用高级语言编程则编译器会自动添加相应的入栈出栈语句。“有人说临时变量不入
栈,
那CPU从子程序运行退回断点时,临时
变量的值是
如何恢复的呢?”呵呵,为何要恢复?调用子程序
的时候
会从局部变量块中新分配空间的,如同你后半部分...
C语言,关于栈的问题
给下面的程序加上注释,并给出运行结果:
答:
x=pop(p);//弹出最顶层元素'k'给x,此时堆栈中有两个元素'a','c'push(p,'t');push(p,x);//将't','k'依次压入堆栈 x=pop(p);//弹出最顶层元素'k'给x,此时堆栈中有三个元素't','a','c'push(p,'s');//将's'
压入堆栈,
此时堆栈中有4个元素's','t','a','c'while...
一道
堆栈的问题
答:
每执行一次PUSH,SP就会减2(一个字的大小,占两个字节),然后将操作数或寄存器压入栈中,执行一次POP,SP就会加2,并将栈顶元素的值送到指定的寄存器中,所以最后SP减2 而(10H)在整个过程中没有改变,所以还是73H,而(A)却在最后一个POP指令改变了其值,也就是最后入
栈的
那个寄存器
的值,
所以也是73H 我...
c++
堆栈中
top
() pop()的具体作用是什么
答:
top
()是取栈顶元素pop()是弹出栈顶元素stack<int> a;a.push(1); // 1a.push(2); // 1 2a.push(3); // 1 2 3int c = a.top(); // c = 3a.pop(); // 1 2a.push(4); // 1 2 4c = a.top(); // c = 4 本回答由电脑网络分类达人 郭强推荐 举报| 答案纠错 | 评论(1...
急求
c语言关于堆栈的
长度
答:
int *
top
;int stacksize;} SqStack;void InitStack(SqStack *S)//创建栈 { S->base=(int*)malloc(STACK_INIT_SIZE*sizeof(int));S->top=S->base;S->stacksize=STACK_INIT_SIZE;} void Push(SqStack *S,int e)//进栈 { if(S->top-S->base>=S->stacksize){ S->base=(int*)...
大家正在搜
c语言实现将坐标压入堆栈中
c语言堆栈的作用
堆栈的使用C语言
c语言实现堆栈
c语言堆栈情况
c语言调用堆栈
c语言堆栈教程
c语言堆栈基本代码
c语言堆栈保存什么
相关问题
c++堆栈中 top() pop()的具体作用是什么
关于入栈,出栈指针和数据操作顺序的疑问
C语言堆栈中如何 创建 销毁 压栈 弹栈 判空 置空 计数
PLC堆栈的问题。
c语言的堆栈是怎么回事!!
用一条MASM语句完成其要求:将堆栈顶部内容弹出送字变量ST...
c语言中函数递归调用中的压入堆栈是什么意思啊
汇编语言中压入堆栈是什么意思