C语言出栈函数Pop返回值

出栈函数Pop为什么要返回1或0,直接返回栈顶元素不行吗?
int Pop(LinkSTACK top, SElemTYPE x)
{
LinkSTACK* s;
/*
如果栈空
return 0;
*/

s=top->next;
*x=s->data;
top->next=s->next;
free(s);
return 1;
}

4个回答

你的描述本身就有几点问题:
1.参数列表处SElemTYPE x应写为SElemTYPE *x,这样才能和函数体里面的赋值语句相呼应。
2.在语句“s=top->next;”后应添加判断分支语句,如下:
if( s == null ) {
return 0;
}
其余的语句是对的。

另外,出栈的时候是有必要判断栈是否为空的,否则可能发生越界。
而这个判断是通过返回值是0还是1来通知外界的。
如果栈不为空,且我们有时需要获取栈顶元素的值,那么就可以通过传地址的方式来保存栈顶的值。
lymboy
lymboy 蟹蟹!
3 年多之前 回复

你的函数定义应该是这样,x前面多了个 * 号;

int Pop(LinkSTACK top, SElemTYPE * x)

这个Pop函数是把栈顶的值赋给 * x;

返回1或者0,那是为了告诉你Pop函数是否成功;

lymboy
lymboy 蟹蟹
3 年多之前 回复

容易引起空指针错误吧

qian337816953
qian337816953 可以自定义
3 年多之前 回复

我的理解是,这里的0/1表示pop函数的状态,若返回1表示有出栈,否则返回0. 如果你想返回栈顶元素的话,当栈为空时,还会出现bug

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐