一步一步写算法(之入栈出栈)

来源:互联网 发布:天天特价淘宝网官网 编辑:程序博客网 时间:2024/06/06 08:49
#include<stdio.h>#include<stdlib.h>#define STACKINCREMENT 10//每次追加栈空间的大小typedef struct{StackElemType *top;//栈顶指针StackElemType *base;//栈底指针int stacksize;//目前为栈分配的空间,以元素为单位}Stack;//栈是否为空bool StackEmpty(Stack S){if(S.base==S.top)return true;elsereturn false;}//入栈void push(Stack &S,StackElemType elem){if(S.top-S.base>=S.stacksize){//栈已满S.base=(StackElemType *)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(StackElemType));if(!S.base)exit(1);//追加空间失败S.top=S.base+S.stacksize;S.stacksize+=STACKINCREMENT;}*S.top++=elem;}//出栈void pop(Stack &S,StackElemType &elem){if(S.base == S.top)exit(1);elem=*--S.top;}

原创粉丝点击