关于栈的操作
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;
} 1.为啥调用这个函数时会返回0?
因为你if中写了return 函数的最后写了return 不管怎样只要调用都会执行return 0
2.如果不写return 0,则程序在运行完这个函数后直接退出。该如何解决这个问题,使得程序运行完这个函数后还可以继续进行其他操作,且不会返回0
如果不写return 0,则程序在运行完这个函数后直接退出-->错 因为你的返回类型决定了你必须要有返回值
这个判断,栈已经空了,所以直接return 0是最好的办法。你不嫌费劲的话,就写个提示,,然后再让人压栈{:5_99:}
页:
[1]