栈和队列--算法设计题3.15

 

   假设以顺序存储结构实现一个双向栈,即在一维数组的存储空间中存在着两个栈,它们的栈底分别设在数组的两个端点。试编写实现这个双向栈tws的三个操作:初始化inistack(tws)、入栈push(tws,i,x)和出栈pop(tws,i)的算法,其中i为0或1,用以分别指示设在数组两端的两个栈.

 

 C  code:

 #include<stdio.h>

#include<stdlib.h>
#define OK 1
#define OVERFLOW -1
#define ERROR 1
typedef 
int Status;

typedef 
struct
{
 
int *base[2];
 
int *top[2];
}BDStack;

Status InitStack(BDStack 
&s,int m)
{
  s.
base[0]=(int*)malloc(m*sizeof(int));
  s.
base[1]=s.base[0]+m;
  s.top[
0]=s.base[0];
  s.top[
1]=s.base[1];
  
return OK;
}

Status push(BDStack 
&s,int i,int x)
{
     
if(s.top[0]>s.top[1]) return OVERFLOW;
     
if(i==0)  *s.top[0]++=x;
     
else if(i==1*s.top[1]--=x;
     
else return ERROR;
     
return OK;
}

Status pop(BDStack 
&s,int i,int x)
{
     
if(i==0)
     {
          
if(s.top[0]==s.base[0]) return OVERFLOW;
          x
=*--s.top[0];
        }
        
else if(i==1)
        {
             
if(s.top[1]==s.base[1]) return OVERFLOW;
             x
=*++s.top[1];
        }
     
else return ERROR;
     
return OK;
}

void PrintfStack(BDStack &s)
{
     
while(s.base[0]<=s.top[0])
     {
          printf(
"%d ",*s.top[0]);
          s.top[
0]--;
        }
        
while(s.top[1]<=s.base[1])
        {
             printf(
"%d ",*s.top[1]);
             s.top[
1]++;
        }
}


int main()
{
     
int m,i;
     BDStack s;
     printf(
"please input the length of the stack: ");
     scanf(
"%d",&m);
     InitStack(s,m);
     
for(i=0; i<(m-2)/2; i++)
     {
          push(s,
0,i);
     }
     
for(i=0; i<(m-2)/2 ; i++)
     {
          push(s,
1,i);
        }
        s.top[
0]--;
     s.top[
1]++;
        PrintfStack(s);
        
return 0;
}
posted @ 2011-05-05 22:06  iwuyudong  阅读(954)  评论(0编辑  收藏  举报