数据结构篇-栈

栈是一种先进后出(LIFO)的线性表,栈规定只能在栈的尾部插入和删除元素;

#include <iostream>
#define INISTACKSIZE 20
#define STACKINCREMENT 10
	/*栈结构*/
	typedef int ElemType;
	typedef struct
	{
		ElemType *base; //栈低指针
		ElemType *top;  //栈顶指针
		int stackSize;  //栈的存储空间大小,栈当前的最大容量

	}sqStack;


	/*栈操作函数*/

	/*初始化栈*/
	void InitStack(sqStack *s)
	{
		std::cout << "ini buffer\n";
		s->base = (ElemType*)malloc(INISTACKSIZE * sizeof(ElemType));
		if (!s->base)
		{
			exit(0);
		}
		s->top = s->base;
		s->stackSize = INISTACKSIZE;
	}

	/*压栈*/
	void PushStack(sqStack *s, ElemType e)
	{

		if (s->top - s->base == s->stackSize)
		{
			std::cout << "new buffer\n";
			s->base = (ElemType*)realloc(s->base, (s->stackSize + STACKINCREMENT) * sizeof(ElemType));
			if (!s->base)
			{
				exit(0);
			}
			s->top = s->base + s->stackSize; //栈重新分配内存后,s->top 重指
			s->stackSize += STACKINCREMENT;
		}

		*(s->top) = e;
		s->top++;

	}

	/*出栈*/
	void PopStack(sqStack *s, ElemType *e)
	{
		if (s->top == s->base)
		{
			return;
		}
		s->top--;
		*e = *(s->top);


	}
	/*栈元素的总数*/
	int GetElemNums(sqStack s)
	{
		return s.top - s.base;
	}

	int main()
	{
		sqStack s;
		InitStack(&s);
		for (int i = 0; i < 51; i++)
		{
			ElemType e = i;
			PushStack(&s, e);
		}
		int cout = GetElemNums(s);
		std::cout << "\n" <<cout << "\n";

		for (int i = 0; i < 51; i++)
		{
			ElemType e = i;
			PopStack(&s, &e);
			std::cout << e << " ";
		}
		cout = GetElemNums(s);
		std::cout << "\n" <<cout << "\n";
		system("PAUSE");
	}

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值