鱼C论坛

 找回密码
 立即注册
查看: 4710|回复: 2

关于栈的操作

[复制链接]
发表于 2021-4-23 17:59:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
int Pop(LinkStack &S,ElemType &x)
{
        LinkStack p;
        if(S==NULL)
        {
                printf("栈为空!\n");
                return 0;//为啥调用这个函数时会返回0?如果不写return 0,则程序在运行完这个函数后直接退出。该如何解决这个问题,使得程序运行完这个函数后还可以继续进行其他操作,且不会返回0。求解决。。。
        }
    x=S->data;p=S;S=S->next;
    delete p;
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-4-23 18:46:40 | 显示全部楼层
1.为啥调用这个函数时会返回0?
因为你if中写了return 函数的最后写了return 不管怎样只要调用都会执行return 0
2.如果不写return 0,则程序在运行完这个函数后直接退出。该如何解决这个问题,使得程序运行完这个函数后还可以继续进行其他操作,且不会返回0
如果不写return 0,则程序在运行完这个函数后直接退出-->错 因为你的返回类型决定了你必须要有返回值
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-24 10:33:32 | 显示全部楼层
这个判断,栈已经空了,所以直接return 0是最好的办法。你不嫌费劲的话,就写个提示,,然后再让人压栈
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-1 21:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表