曦~~ 发表于 2021-4-23 17:59:00

关于栈的操作

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;
}

肖-肖 发表于 2021-4-23 18:46:40

1.为啥调用这个函数时会返回0?
因为你if中写了return 函数的最后写了return 不管怎样只要调用都会执行return 0
2.如果不写return 0,则程序在运行完这个函数后直接退出。该如何解决这个问题,使得程序运行完这个函数后还可以继续进行其他操作,且不会返回0
如果不写return 0,则程序在运行完这个函数后直接退出-->错 因为你的返回类型决定了你必须要有返回值

2269099035 发表于 2021-4-24 10:33:32

这个判断,栈已经空了,所以直接return 0是最好的办法。你不嫌费劲的话,就写个提示,,然后再让人压栈{:5_99:}
页: [1]
查看完整版本: 关于栈的操作