数据结构---栈

xiaoxiao2021-02-27  448

栈是一种线性表的特殊表现形式,与队列的先进先出不同,栈是按照后进先出的原则处理数据。

typedef struct

{         DATA data[SIZE+1];         int top; }SeqStack; SeqStack *SeqStackInit() {         SeqStack *p;         if(p = (SeqStack *)malloc(sizeof(SeqStack)))         {                 p->top = 0;                 return p;         }         return NULL; } void SeqStackFree(SeqStack *s) {         if(s)                 free(s); } int SeqStackIsEmpty(SeqStack *s) {         return(s->top == 0); } void SeqStackClear(SeqStack *s) {         s->top = 0; } int SeqStackIsFull(SeqStack *s) {         return(s->top == SIZE); } int SeqStackPush(SeqStack *s,DATA data) {         if((s->top+1) > SIZE)         {                 printf("stack is full\n");                 return 0;         }         s->data[++s->top] = data;         return 1; } DATA SeqStackPop(SeqStack *s) {         if(s->top == 0)         {                 printf("stack is empty");                 exit(0);         }         return(s->data[s->top--]); } DATA SeqStackPeek(SeqStack *s) {         if(s->top == 0)         {                 printf("stack is empty");                 exit(0);         }         return (s->data[s->top]); }
转载请注明原文地址: https://www.6miu.com/read-1037.html

最新回复(0)