栈代码

顺序栈

#include <stdio.h>

#include <stdlib.h>

#define MAXSIZE 20

#define OK 1

#define ERROR 0

 

typedef int data_t;

typedef struct

{

data_t data[MAXSIZE];

int top;

}SqStack;

 

int PushStack(SqStack *s,data_t e)//压栈

{

if(s->top==MAXSIZE-1)

{

printf("Stack is Full\n");

return ERROR;

}

s->top++;

s->data[s->top]=e;

return OK;

}

 

int PopStack(SqStack *s,data_t *e)//弹栈

{

if(s->top==-1)

{

printf("Stack is Empty\n");

return ERROR;

}

*e=s->data[s->top];

s->top--;

return OK;

}

SqStack* CreateEmptyStack()//创建栈

{

    SqStack *stack = (SqStack*)malloc(sizeof(SqStack));

    if(stack==NULL)

    {

        printf("CreateEmptyStack Error\n");

        exit(0);

    }

    stack->top=-1;

    return stack;

}

int EmptyStack(SqStack *s)//判断栈是否是空栈

{

    return -1==s->top?OK:ERROR;

}

int FullStack(SqStack *s)//判断栈是否是满栈

{

    return MAXSIZE-1==s->top?OK:ERROR;

}

int ClearStack(SqStack *s)//清空栈内元素

{

    s->top=-1;

    return OK;

}

int main()

{

/*

    SqStack *stack = CreateEmptyStack();

    data_t data;

    PushStack(stack,20);

    PushStack(stack,30);

    PopStack(stack,&data);

    printf("pop:%d\n",data);

    PopStack(stack,&data);

    printf("pop:%d\n",data);

    PopStack(stack,&data);

    printf("pop:%d\n",data);

    if(EmptyStack(stack)==OK)

        printf("Stack is Empty!\n");

    if(FullStack(stack)==OK)

        printf("Stack is Full!\n");

*/

    return 0;

}


链式栈

#include <stdio.h>

#include <stdlib.h>

 

#define OK 1

#define ERROR 0

typedef int data_t;

typedef struct StackNode

{

data_t data;

struct StackNode *next;

}LinkStack;

LinkStack *CreateEmptyStack()//创建栈

{

LinkStack *s;

s = (LinkStack*)malloc(sizeof(LinkStack));

if(s==NULL)

{

perror("Create Empty Stack Error");

exit(0);

}

s->next=NULL;

return s;

}

int ClearLinkStack(LinkStack *stack)//清空栈

{

if(!stack)

return ERROR;

LinkStack *node;

while(stack->next!=NULL)

{

node=stack->next;

stack->next=node->next;

free(node);

}

return OK;

}

int DestroyLinkStack(LinkStack *stack)//销毁栈

{

if(stack)

ClearLinkStack(stack);

free(stack);

stack=NULL;

return OK;

}

int EmptyLinkStack(LinkStack *stack)//判断栈是否为空

{

if(stack==NULL)

{

printf("Empty Error\n");

return -1;

}

else

{

return NULL==stack->next?OK:ERROR;

}

}

int PushStack(LinkStack *s,data_t e)//压栈

{

if(s==NULL)

{

printf("PushStack Error\n");

return ERROR;

}

LinkStack *p=(LinkStack*)malloc(sizeof(LinkStack));

p->data=e;

p->next=s->next;

s->next=p;

return OK;

}

int PopStack(LinkStack *s,data_t *e)//弹栈

{

LinkStack *p;

if(s==NULL)

{

printf("PopStack Error\n");

return ERROR;

}

if(EmptyLinkStack(s)==OK)

{

printf("The Stack is Empty\n");

return ERROR;

}

*e=s->next->data;

p=s->next;

s->next=s->next->next;

free(p);

return OK;

}

 

int main()

{

/*

data_t data;

LinkStack *stack = CreateEmptyStack();

PushStack(stack,20);

PushStack(stack,30);

PopStack(stack,&data);

printf("Pop:%d\n",data);

PopStack(stack,&data);

printf("Pop:%d\n",data);

PopStack(stack,&data);

printf("Pop:%d\n",data);

PushStack(stack,20);

PushStack(stack,30);

if(DestroyLinkStack(stack)==OK)

{

printf("Desroy LinkStack Success\n");

}

return 0;

*/

}


  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值