【数据结构】栈的基本操作

取栈顶元素、插入、删除栈元素

#include<iostream>
#include<cstdlib>
#define SElemType int
#define Status int
#define OK 1
#define ERROR 0
#define STACK_INIT_SIZE 100 
#define STACKINCREMENT 10
#define OVERFLOW 0
using namespace std;
typedef struct{
	SElemType *base;
	SElemType *top;
	int stacksize; 
}SqStack;
Status StackInit(SqStack &S){
	S.base=(SElemType*)malloc(sizeof(SElemType)*STACK_INIT_SIZE);
	if(!S.base) exit(OVERFLOW);
	S.top=S.base;//栈空 
	S.stacksize=STACK_INIT_SIZE;
	return OK;
}
Status GetTop(SqStack S,int &e){
	//栈空
	if(S.base==S.top) return ERROR;
	e=*(S.top-1);
	return OK; 
}
Status StackInsert(SqStack &S,int &e){
	//栈满
	if(S.top-S.base>=S.stacksize){
		S.base=(SElemType*)realloc(S.base,sizeof(SElemType)*(S.stacksize+STACKINCREMENT));
		if(!S.base) exit(OVERFLOW);
		S.top=S.base+S.stacksize;
		S.stacksize+=STACKINCREMENT; 
	} 
	*S.top++=e;
	return OK;
} 
Status StackDelete(SqStack &S,int &e){
	//如果栈空
	if(S.base==S.top) return ERROR;
	e=*--S.top;
	return OK; 
}
int main(){
	SqStack S;
	StackInit(S);
	int n,x,e;
	cout<<"插入的数的个数:";
	cin>>n;
	cout<<"插入的数为:";
	for(int i=0;i<n;i++){
		cin>>x;
		StackInsert(S,x);
	} 
	cout<<"当前的数为: ";
	//遍历栈
	int *p=S.base;
	for(;p!=S.top;p++){
		cout<<*p<<" ";
	} 
	//得到栈顶元素
	cout<<endl<<endl<<"栈顶元素为:";
	GetTop(S,e);
	cout<<e<<endl; 
	//添加元素
	cout<<endl<<"添加元素:";
	cin>>x;
	StackInsert(S,x);
	cout<<"此时的栈为:";
	for(p=S.base;p!=S.top;p++){
		cout<<*p<<endl;
	} 
	//删除元素
	cout<<endl<<endl<<"删除操作"<<endl;
	StackDelete(S,e);
	cout<<"删除元素为: "<<e<<endl;
	cout<<"此时的栈为: ";
	for(p=S.base;p!=S.top;p++) cout<<*p<<" "; 
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值