#define error 0,宏定义,你懂得。
return error,就是return 0
而return OK就是return 1(头文件中宏定义了OK为1)
一个函数如果碰到了return,这个函数就不再往下执行了,直接跳出函数。
补充:对于被调函数,没有区别,都不往下执行了。但是对于主调函数,可以根据被调函数的返回值(0或者1)来执行相应的动作。
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