【数据结构】顺序栈

顺序栈

一、相关概念

  1. 栈和队列是操作受限的线性表,是限定性的数据结构;
  2. 栈分为顺序栈和链式栈
  3. 栈只能在一端进行操作(插入、删除)
  4. 栈是限定仅在表尾进行插入或删除操作的线性表,因此,对栈来说,表尾端具有特殊含义,称为栈顶(top),相应的,表头端称为栈底(bottom)
  5. 不含元素的空表称为空栈

二、顺序栈的结构

复制代码
typedef struct Stack
{
	int* base; //指向动态内存
	int top; //栈顶指针,实际上是下标
	int stacksize; //栈的总大小
}Stack, *PStack;

三、顺序栈的实现

cpp 复制代码
#define INIT_SIZE 10
//初始化
void InitStack(PStack ps)
{
	assert(ps != NULL);
	ps->base = (int*)malloc(INIT_SIZE * sizeof(int*));
	ps->top = 0;
	ps->stacksize = INIT_SIZE;
}
static bool IsFull(PStack ps)
{
	return ps->top == ps->stack;
}
static void Inc(PStack ps)
{
	ps->stacksize *= 2;
	ps->base = (int*)realloc(ps->base, ps->stacksize * sizeof(int));
	assert(ps->base != NULL); 
}
//入栈操作
bool Push(PStack ps, int val)
{
	assert(ps != NULL);
	if(IsFull)
		Inc(ps);
	ps->base[ps->top++] = val;
	return true;
}
//获取栈顶元素的值,但是不删除
//输出参数
bool GetTop(PStack ps, int *rtval)
{
	assert(ps != NULL);
	if(IsEmpty(ps))
		return false;
	*rtval = ps->base[ps->top - 1];
	return true;
}
//获取栈顶元素的值,但是删除
bool Pop(PStack ps, int *rtval)
{
	assert(ps != NULL);
	if(IsEmpty(ps))
		return false;
	*rtval = ps->base[--ps->top];
	return true;
}
//判空
bool IsEmpty(PStack ps)
{
	return ps->top == 0;
}
//获取栈中有效元素的个数
int GetLength(PStack ps)
{
	assert(ps != NULL);
	return ps->top;
}
//清空所有的数据
void Clear(PStack ps)
{
	assert(ps != NULL);
	ps-> top = 0;
}
//销毁
void Destroy(PStack ps)
{
	assert(ps != NULL);
	free(ps->base);
	ps->base = NULL;
	ps->top = 0;
	ps-> =stacksize;
}

四、顺序栈的总结

  1. 栈的特点:后进后出,后来的反而需要先服务(访问受限的线性表)
  2. 栈又分为顺序栈和链式栈
  3. 本篇顺序栈为不定长的顺序栈,能自动扩容
  4. 栈只能在一端进行插入和删除,插入和删除这一端称之为栈顶,另一端称之为栈底
  5. 顺序栈的栈顶在尾部,因为入栈和出栈的时间复杂度为O(1)
相关推荐
Jasmine_llq5 分钟前
《CF280C Game on Tree》
数据结构·算法·邻接表·深度优先搜索(dfs)·树的遍历 + 线性累加统计
小棠师姐13 分钟前
支持向量机(SVM)入门:超平面与核函数的通俗解释
算法·python机器学习·支持向量机svm·超平面可视化·核函数应用
zhongvv17 分钟前
对单片机C语言指针的一些理解
c语言·数据结构·单片机·指针·汇编语言
佛系打工仔30 分钟前
绘制K线第一章:可见区间处理
java
wangkay8835 分钟前
【Java 转运营】Day02:抖音直播间流量底层逻辑全解析
java·新媒体运营
im_AMBER39 分钟前
Leetcode 102 反转链表
数据结构·c++·学习·算法·leetcode·链表
5***b971 小时前
Spring Boot--@PathVariable、@RequestParam、@RequestBody
java·spring boot·后端
今儿敲了吗1 小时前
01|多项式输出
c++·笔记·算法
AIGCExplore1 小时前
Jenkins 全局配置及工具验证教程
java·servlet·jenkins
qq_318121591 小时前
Java大厂面试故事:Spring Boot、微服务与AI场景深度解析
java·spring boot·redis·微服务·ai·kafka·spring security