lymboy 2017-06-15 10:22 采纳率: 100%
浏览 4270
已采纳

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条回答 默认 最新

  • yangc_cong 2017-06-15 14:49
    关注

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

    另外,出栈的时候是有必要判断栈是否为空的,否则可能发生越界。
    而这个判断是通过返回值是0还是1来通知外界的。
    如果栈不为空,且我们有时需要获取栈顶元素的值,那么就可以通过传地址的方式来保存栈顶的值。
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 Java与Hbase相关问题
  • ¥20 bash代码推送不上去 git fetch origin master #失败了
  • ¥15 LOL外服加入了反作弊系统,现在游戏录像rofl文件离线都无法打开
  • ¥45 工程软件单片机设计课题要求
  • ¥15 在centos7安装conda
  • ¥15 c#调用yolo3 dll文件获取的数据对不上
  • ¥20 WPF 如何实现多语言,label 和cs(live Charts)中是否都能翻译
  • ¥15 STM32F103上电短路问题
  • ¥15 打开软件提示错误:failed to get wglChoosePixelFormatARB
  • ¥15 (标签-python|关键词-char)