共享栈基本操作

#include  <stdio.h>
#include  <stdlib.h>
#include  <string.h>


#define  StackSize      100
//DataType为元素的数据类型,stack用于存储共享栈中的数据元素的数组
//top[0]和top[1]为栈顶数组下标
typedef     char  DataType;
typedef  struct   
{
    DataType    stack[StackSize];
    int         top[2];    
}SSeqStack;

//初始化栈
void   SStackInit(SSeqStack  *S)
{
    S->top[0]=0;
    S->top[1]=StackSize-1;
}


//取栈顶元素.flag为1表示取左端元素,flag为2表示取右端元素
int     GetTopS(SSeqStack S, DataType  *e,int flag)
{
if(flag==1)
{
    if(S.top[0]<=0)
    {
        printf("左栈已经空!\n");
        return  0;
    }
    else
    {
        *e=S.stack[S.top[0]-1];
        return 1;
    }
}
else  if(flag==2)
{
    if(S.top[1]>=StackSize-1)
    {
        printf("右栈已经空!\n");
        return  0;
    }
    else
    {
        *e=S.stack[S.top[1]+1];
        return 1;
    }    
}
else
{
    printf("不正确的参数!\n");
    return 0;
}

}

//将元素入栈
int     PushSStack(SSeqStack  *S, DataType  e, int  flag)
{
if(flag==1)
{
    if(S->top[0]>=S->top[1])//栈满的条件是相等还是大于?认为均可以
    {
        printf("栈已经满!\n");
        return 0;
    }
    else
    {
        S->stack[S->top[0]]=e;
        S->top[0]++;
        return 1;
    }
}
else  if(flag==2)
{
    if(S->top[0]>=S->top[1] )
    {
        printf("栈已经满!\n");
        return 0;
    }
    else
    {
        S->stack[S->top[1]]=e;
        S->top[1]--;
        return 1;
    }    
}
else
{
    return 0;
}
}

//将栈顶元素出栈
int    PopSStack(SSeqStack  *S,  DataType  *e,int flag)
{
if(flag==1)
{
        if(S->top[0]==0)
        {
            printf("左栈已经空!\n");
            return 0;
        }
        else
        {
            S->top[0]--;
            *e=S->stack[S->top[0]];
            return   1;
        }
}
else  if(flag==2)
{
        if(S->top[1]==StackSize-1)
        {
            printf("右栈已经空!\n");
            return 0;
        }
        else
        {
            S->top[1]++;
            *e=S->stack[S->top[1]];
            return   1;
        }    
}
else
{
        return 0;
}
}


//清空栈
void    ClearSStack(SSeqStack  *S)
{
    S->top[0]=0;
    S->top[1]=StackSize-1;
}

int     main()
{
    DataType  a[]={'a','b','c','d','e','f'};
    DataType  b[]={'p','w','x','y','z'};
    SSeqStack  B;
    DataType   e1, e2;
    int i=0;
    SStackInit(&B);
    for(i=0;i<sizeof(a)/sizeof(DataType);i++)
    {
        PushSStack(&B,a[i],1);
    }
    for(i=0;i<sizeof(b)/sizeof(DataType);i++)
    {
        PushSStack(&B,b[i],2);
    }
    for(i=0;i<sizeof(a)/sizeof(DataType);i++)
    {
        PopSStack(&B,&e1,1);
        printf("%c ",e1);
    }    
    printf("\n******************\n");
    for(i=0;i<sizeof(b)/sizeof(DataType);i++)
    {
        PopSStack(&B,&e2,2);
        printf("%c ",e2);
    }     
    return  0;
}
复制代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值