用一个数组实现两个堆栈
Posted Zack-Scu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用一个数组实现两个堆栈相关的知识,希望对你有一定的参考价值。
#include <stdio.h> #include <stdlib.h> #define ElementType int const int MAXSIZE = 10; typedef struct Node *DStack; typedef struct Node{ ElementType Data[MAXSIZE]; int last0; int last1; }; bool Push(int flag,DStack &S, ElementType X){//0代表插入栈0,1代表插入栈1 //printf("------------------------------------\\n"); if(S->last0==S->last1-1){ printf("栈满\\n"); return 0; } //printf("------------------------------------\\n"); if(flag==0){ S->Data[++S->last0] = X; return true; }else if(flag == 1){ S->Data[--S->last1]=X; return true; }else{ printf("插入序号有误\\n"); return false; } } ElementType Pop(int flag,&DStack S){ if((flag==0 && S->last0==-1)||(flag==1 && S->last1 == MAXSIZE)){ printf("栈空"); return 0; } if(flag ==0) return S->Data[S->last0--]; else if(flag ==1) return S->Data[S->last1++]; else{ printf("插入序号有误\\n"); return 0; } } void InintDStack(DStack &S){ S = (DStack)malloc(sizeof(struct Node)); S->last0 = -1; S->last1= MAXSIZE; } int main(){ DStack S; InintDStack(S); for(int i = 0;i<12;i++){ Push(i%2,S,i); } for(int i=0;i<12;i++){ printf("%d\\n",Pop(i%2,S)); } return 0; }
以上是关于用一个数组实现两个堆栈的主要内容,如果未能解决你的问题,请参考以下文章