顺序栈

添加头文件

声明宏定义

设计数据结构

功能函数声明

具体功能实现







简单调用测试

int main()
{
	Stack* stack = creat_stack(15);  // 创建容量为15的栈
	printf("开始入栈:");
	for(int i=0; i<20; i++)
	{
		printf("入栈%s,",push_stack(stack,i)?"成功":"失败");
		printf("栈顶:%d\n",*top_stack(stack));
		// 两个printf不能写在一起,函数的参数是从右往左加,若是两个printf写在一起,栈顶函数会先被执行,造成段错误
	}
	printf("------------------------\n开始出栈:\n");
	for(int i=0; i<15; i++)
	{
		printf("栈顶:%2d,",*top_stack(stack));
		printf("出栈:%s\n",pop_stack(stack)?"成功":"失败");
		// 若先出栈再看栈顶,最后一个会段错误
		// i若加到大于15也会有段错误
	}
}

结果


总结

注意:基础还是数组
创建:初始化栈空间、长度、栈顶,最后返回栈
销毁:可以直接释放
入栈:栈非满,在相应位置填上相应数据,返回真
出栈:栈非空,直接移动栈顶,成功返回真
:出栈可以不用把数据清除,把指针往前移就好了,下次入栈时会将原数据覆盖
栈空:通过栈顶判断
栈满:通过栈顶判断
栈顶:返回其大小

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值