⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 stack8b.c

📁 THINKING IN C 源码
💻 C
字号:
/* stack8b.c: implementation */
#include "stack8b.h"
#include <stdlib.h>

struct Stack {
    int *data;
    int size;
    int ptr;
    int error;
};

Stack* stk_create(int stk_size) {
    Stack* stkp = malloc(sizeof(Stack));
    stkp->size = stk_size;
    stkp->data = malloc(stkp->size*sizeof(int));
    stkp->ptr = stkp->error = 0;
    return stkp;
};

void stk_push(Stack* stkp, int x) {
    if (stkp->ptr < stkp->size) {
        stkp->data[stkp->ptr++] = x;
        stkp->error = 0;
    }
    else
        stkp->error = 1;
}

int stk_pop(Stack* stkp) {
    if (stkp->ptr > 0) {
        int x = stkp->data[--stkp->ptr];
        stkp->error = 0;
        return x;
    } else {
        stkp->error = 1;
        return STK_ERROR;
    }
}

int stk_top(Stack* stkp) {
    if (stkp->ptr > 0) {
        stkp->error = 0;
        return stkp->data[stkp->ptr-1];
    } else {
        stkp->error = 1;
        return STK_ERROR;
    }
}

int stk_size(Stack* stkp) {
    return stkp->ptr;
}

int stk_error(Stack* stkp) {
    return stkp->error;
}

void stk_destroy(Stack* stkp) {
    free(stkp->data);
    free(stkp);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -