6、栈

1、顺序栈

#include<stdio.h>
#include<malloc.h>
#include<assert.h>

#define ElemType int

#define STACK_INIT_SIZE 8
#define STACK_INC_SIZE  3


//顺序栈的定义 
typedef struct SeqStack{
    ElemType *base;
    int       capacity;
    int       top;    
}SeqStack;

//初始化顺序栈 
void init_SeqStack(SeqStack* st){
    st->base = (ElemType*)malloc(sizeof(ElemType) * STACK_INIT_SIZE);
    st->capacity = STACK_INIT_SIZE;
    /*
    top可为 -1 [入栈:先top++在放值 出栈: 先取值在top--] 
       也可为 0 [入栈:先放值在++ 出栈: 先--在放值] 
    */
    st->top = 0;
}

//判断栈是否已满[为真返回1 为假返回0 ] 
int isFull(SeqStack* st){
    return st->top >= st->capacity;
}

//判断栈是否为空[为真返回1 为假返回0 ]
int isEmpty(SeqStack* st){
    return st->top == 0;
}

int inc_stack(SeqStack* st){
    ElemType* newBase = (ElemType*)realloc(st->base,sizeof(ElemType) * (st->capacity + STACK_INC_SIZE));
    if(newBase == NULL){
        printf("内存空间不足,无法申请空间.\n");
        return 0;
    }
    st->base = newBase;
    st->capacity += STACK_INC_SIZE;
    return 1;
}

//入栈
void push(SeqStack* st,ElemType e){
    if(isFull(st) && !inc_stack(st)){
        printf("栈空间已满,%d 不能入栈.\n",e);
        return;
    }
    //如果top为-1 =>  st->base[++st->top] = e;
    st->base[st->top++] = e;
}

//出栈
ElemType pop(SeqStack* st){
    if(isEmpty(st)){
        printf("栈空间已空,不能出栈.\n");
        return;
    } 
    //如果top为-1 =>  return st->base[st->top--];
    return st->base[--st->top]; 
} 

//得到栈顶元素,但不出栈
ElemType get_top(SeqStack* st){
    if(isEmpty(st)){
        printf("栈空间已空,不能出栈.\n");
        return;
    } 
    return st->base[st->top - 1];
}

//栈的长度
int length(SeqStack* st){
    return st->top;
} 

//清空栈
void clear(SeqStack* st){
    st->top = 0;
}

//销毁栈
void destroy(SeqStack* st){
    free(st->base);
    st->capacity = st->top = 0;
} 

//打印栈
void show_stack(SeqStack* st){
    int i = st->top - 1;
    for(i;i >= 0;i--){
        printf("%d\n",st->base[i]);
    }
    printf("\n");
}
int main(){
    SeqStack st;
    init_SeqStack(&st);
    int i = 1;
    for(i;i <= 5;i++){
        push(&st,i);
    }
    show_stack(&st);
    pop(&st);
        show_stack(&st);

    return 0;
} 

2、链栈

#include<stdio.h>
#include<malloc.h>
#include<assert.h>

#define ElemType int

typedef struct StackNode{
    ElemType data;
    struct StackNode* next;
}StackNode;

typedef StackNode* LinkStack;

//注意 这里是二级指针 
void initStack(LinkStack* st){
    st = NULL;
}

StackNode* malloc_statckNode(ElemType e){
    StackNode* p = (StackNode*)malloc(sizeof(StackNode));
    assert(p != NULL);
    p->data = e;
    p->next = NULL;
} 

//入栈 
void push(LinkStack* st,ElemType e){
    StackNode* p = malloc_statckNode(e);
    if(*st == NULL){
        //当前栈空间为空 ,新节点直接为栈顶 
        *st = p;
    } else {
        //新节点指向栈顶 
        p->next = *st;
        //更换栈顶 
        *st = p;
    }
} 

//出栈
ElemType pop(LinkStack* st) {
    if(*st == NULL){
        printf("当前栈空间为空,不可出栈.\n"); 
        return;
    }
    StackNode* top = *st;
    *st = top->next;
    ElemType e = top->data;
    free(top);
    return e;
}
//打印栈
void show(LinkStack* st){
    LinkStack s = *st;
    while(s != NULL){
        printf("%d\n",s->data);
        s = s->next;
    }
    printf("\n");
}
int main(){
    LinkStack st;
    //二级指针接收一级指针的地址 
    initStack(&st);
    int i = 1;
    for(i;i <= 5;i++){
        push(&st,i);
    }
    show(&st);
    pop(&st);
    show(&st);

    return 0;
}

 

posted @ 2024-09-16 15:45  颜欢兮  阅读(3)  评论(0编辑  收藏  举报