3_顺序栈的基本操作

/****date:2014.12.08*****/
/***顺序栈的基本操作***/ /*** Last in First out ( LIFO ) ***/

顺序栈:使用地址连续的内存单元依次保存栈中的数据,可以定义一个指定大小的结构数组来作为栈;栈底元素序号为0,栈顶元素序号为Top;

栈内元素遵循“后进先出“(LIFO)原则;只能在栈的一端进行操作,即在栈顶位置对栈内元素进行操作。


刚明白的道理:getchar() 对于 键盘的所有操作都算在内,敲击  回车键  也算一个输入信号。

 
#define MAXLEN 3

typedef struct  
{
char name[10];
int age;
}DATA;


typedef struct stack
{
DATA data[MAXLEN+1];
int top;

}StackType;


//初始化栈
StackType * SInit()
{
StackType * p;
if (p=(StackType *)malloc(sizeof(StackType)));
{
p->top=0;
return p;
}
return NULL;

}


//判断空栈
int SIsEmpty(StackType * s)
{
int t;
t=(s->top==0);
return t;

}


//判断满栈
int SIsFull(StackType * s)
{
int t;
t=(s->top==MAXLEN);
return t;

}


//清空栈
void SClear(StackType * s)
{
s->top=0;

}


//释放空间
void SFree(StackType * s)
{
if (s)
{
free(s);
}

}


//入栈操作
int SPush(StackType * s,DATA data)
{
if (s->top+1>MAXLEN)
{
printf("栈溢出\n");
return 0;
}
else
{
s->data[++s->top]=data;
return 1;
}

}


//出栈操作
DATA SPop(StackType * s)
{
if (s->top==0)
{
printf("栈已经为空\n");
system("pause");
//return 0;
exit(0);

else
{
return (s->data[s->top--]);
}

}


//读取栈顶信息
DATA SGetTop(StackType * s)
{
if (s->top==0)
{
printf("栈为空\n");
//return 0;
exit(0);

else
{
return (s->data[s->top]);
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值