数据结构(c语言版)RETURN问题求教
比如说在给链表动态分配内存的时候分配不成功时有returnerror这表示什么意思啊执行了以后就直接跳出函数不往下执行了吗可是宏定义是#defineerror0;返回0就...
比如说在给链表动态分配内存的时候 分配不成功时 有 return error
这表示什么意思啊 执行了以后就直接跳出函数不往下执行了吗 可是 宏定义是
#define error 0; 返回0就就往下执行了?? return OK;才往下执行 可是C语言好像没这回事吧
那return error 和return OK 还有区别吗 不是都不往下执行了?? 展开
这表示什么意思啊 执行了以后就直接跳出函数不往下执行了吗 可是 宏定义是
#define error 0; 返回0就就往下执行了?? return OK;才往下执行 可是C语言好像没这回事吧
那return error 和return OK 还有区别吗 不是都不往下执行了?? 展开
4个回答
展开全部
main函数中return 是指把控制权交还给操作系统,后面的0和1是返回给操作系统的状态,操作系统可以根据这个值判断函数的执行情况并做一些相应的处理。普通函数中的return是给调用函数返回一个状态值
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
STACK_INIT_SIZE 100
#define OVERFLOW -1
#define OK 1
#define TRUE 1
#define FALSE 0
typedef int SElemType;
typedef int Status;
typedef struct {
SElemType *base; // 存储空间基址
SElemType * top; // 栈顶指针
int stacksize; // 允许的最大存储空间
// 以元素为单位
} SqStack;
Status InitStack (SqStack &S){
S.base = new SElemType[STACK_INIT_SIZE];
if (!S.base) exit (OVERFLOW); //存储分配失败
S.top = S.base;
S.stacksize = STACK_INIT_SIZE;
return OK;
}
Status Push (SqStack &S, SElemType e) {
//插入元素e为新的栈顶元素
if (S.top – S.base > = S.stacksize) //栈满
return OVERFLOW;
* S. top++ = e;
return OK;
}
Status Pop (SqStack &S, SElemType &e) {
//若栈不空,则删除S的栈顶元素,用e返回其值,
//并返回OK;否则返回ERROR
if (S.top = = S.base )
return ERROR;
e = * --S.top;
return OK;
}
Status StackEmpty (SqStack S)
{//若栈S为空栈,则返回TRUE,否则返回 FALSE。
if (S.top = = S.base )
return TRUE;
else return FALSE;
}
void conversion () {
// 对于输入的任意一个非负十进制整数,
//打印输出与其等值的八进制数
SqStack S;
int N;
InitStack(S); // 构造空栈
print("请输入一个非负十进制整数:\n");
scanf("%d",&N); // 输入一个十进制数
do{
Push(S, N % 8); // "余数"入栈
N = N/8; // 非零"商"继续运算
} while (N) ;
while (!StackEmpty(S)) {
// 和"求余"所得相逆的顺序输出八进制的各位数
Pop(S,e);
printf("%d",e);
}
} // conversion
#define OVERFLOW -1
#define OK 1
#define TRUE 1
#define FALSE 0
typedef int SElemType;
typedef int Status;
typedef struct {
SElemType *base; // 存储空间基址
SElemType * top; // 栈顶指针
int stacksize; // 允许的最大存储空间
// 以元素为单位
} SqStack;
Status InitStack (SqStack &S){
S.base = new SElemType[STACK_INIT_SIZE];
if (!S.base) exit (OVERFLOW); //存储分配失败
S.top = S.base;
S.stacksize = STACK_INIT_SIZE;
return OK;
}
Status Push (SqStack &S, SElemType e) {
//插入元素e为新的栈顶元素
if (S.top – S.base > = S.stacksize) //栈满
return OVERFLOW;
* S. top++ = e;
return OK;
}
Status Pop (SqStack &S, SElemType &e) {
//若栈不空,则删除S的栈顶元素,用e返回其值,
//并返回OK;否则返回ERROR
if (S.top = = S.base )
return ERROR;
e = * --S.top;
return OK;
}
Status StackEmpty (SqStack S)
{//若栈S为空栈,则返回TRUE,否则返回 FALSE。
if (S.top = = S.base )
return TRUE;
else return FALSE;
}
void conversion () {
// 对于输入的任意一个非负十进制整数,
//打印输出与其等值的八进制数
SqStack S;
int N;
InitStack(S); // 构造空栈
print("请输入一个非负十进制整数:\n");
scanf("%d",&N); // 输入一个十进制数
do{
Push(S, N % 8); // "余数"入栈
N = N/8; // 非零"商"继续运算
} while (N) ;
while (!StackEmpty(S)) {
// 和"求余"所得相逆的顺序输出八进制的各位数
Pop(S,e);
printf("%d",e);
}
} // conversion
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询