【数据结构初阶(4)】栈的基本操作实现

文章目录

  • Ⅰ 概念及结构
    • 1. 栈的概念
    • 2. 栈的操作
  • Ⅱ 基本操作实现
    • 1. 栈的定义
    • 2. 初始化栈
    • 3. 元素入栈
    • 4. 元素出栈
    • 5. 获取栈顶元素
    • 6. 获取栈中有效元素个数
    • 7. 判断栈空
    • 8. 销毁栈

Ⅰ 概念及结构

1. 栈的概念

  • :栈是一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作
  • 栈顶和栈底:进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出的原则
  • 空栈:不含任何元素的栈

2. 栈的操作

  • 入栈:在栈顶插入数据称为入栈 (压栈 / 进栈),入数据在栈顶
  • 出栈:在栈顶删除数据称为出栈 (弹栈),出数据在栈顶

在这里插入图片描述

Ⅱ 基本操作实现

1. 栈的定义

  • 栈一般用数组或链表来实现,使用数组栈在入栈上会更轻松,因此本文使用的为数组栈 (顺序栈)。

代码实现

// 支持动态增长的栈
typedef int STDataType;

typedef struct stack
{
	STDataType* data;	//栈空间
	int top;			//栈顶
	int capacity;		//容量 
}stack;

2. 初始化栈

实现方法

先将栈空间置空,栈顶置为 -1,栈空间容量置为 0。

  • 栈顶置为 -1,表示指向当前元素。因为本文使用的为数组栈,栈顶实际上是最后一个元素的下标,如果栈顶初始化为 0 的话,就没法很好的表示栈内是没有元素还是只有一个元素。

代码实现

// 初始化栈 
void StackInit(stack* ps)
{
	assert(ps);

	ps->data = NULL;	//栈空间置空
	ps->top = -1;		//栈顶
	ps->capacity = 0;	
}

3. 元素入栈

  • 栈顶指针 top 指向的是当前的元素,在插入新元素时需要先将栈顶指针 + 1,指向栈顶之上。

在这里插入图片描述

代码实现

// 入栈 
void StackPush(stack* ps, STDataType data)
{
	assert(ps);

	if (ps->top + 1 == ps->capacity)	//检查栈空间是否需要扩容
	{
		int newcapacity = ps->capacity == 0 ? 4 : 2 * ps->capacity;

		STDataType* tmp = 
		(STDataType*)realloc(ps->data, sizeof(STDataType) * newcapacity);

		if (NULL == tmp)
		{
			perror("realloc");
			exit(-1);
		}

		ps->data = tmp;
		ps->capacity = newcapacity;
	}

	ps->top++;					//栈顶指针指向栈顶之上
	ps->data[ps->top] = data;	//元素入栈
}

4. 元素出栈

  • 若栈不为空,则直接将栈顶指针 - 1 即可,只有在栈顶指针维护下的元素才是有效数据。
// 出栈 
void StackPop(stack* ps)
{
	assert(ps);
	assert(ps->top > -1);	//栈不为空

	ps->top--;				//栈顶指针 - 1
}

5. 获取栈顶元素

  • 若栈不为空,则直接返回栈顶指针指向的那块空间的数据即可。
// 获取栈顶元素 
STDataType StackTop(stack* ps)
{
	assert(ps);
	assert(ps->top > -1);		//栈不为空

	return ps->data[ps->top];	//返回栈顶元素
}

6. 获取栈中有效元素个数

  • 因为栈顶指针实际表示的是数组下标,所以栈中有效数据的个数为 top+1。
// 获取栈中有效元素个数 
int StackSize(stack* ps)
{
	assert(ps);

	return ps->top + 1;
}

7. 判断栈空

  • 在初始化栈时将栈顶指针初始化为 -1表示栈空,可以直接用 -1 是否等于 top 来判断是否栈空。
// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0 
int StackEmpty(stack* ps)
{
	assert(ps);

	return -1 == ps->top;	
}

8. 销毁栈

// 销毁栈 
void StackDestroy(stack* ps)
{
	assert(ps);

	free(ps->data);				//释放栈空间
	ps->data = NULL;
	ps->top = ps->capacity = 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/180551.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SAP QA11/QA32质检放行时,如何处理产生记账更改通知单时

前提:启用SAP wms仓库管理 场景: 当做移动类型321质检放行的时候,有时候会产生记账更改通知单,这个时候怎么处理? 解决办法: 使用事务码LU04,查看未清的记账更改通知单,进入清单列表之后&…

【深度学习】卷积神经网络(CNN)的参数优化方法

著名: 本文是从 Michael Nielsen的电子书Neural Network and Deep Learning的深度学习那一章的卷积神经网络的参数优化方法的一些总结和摘录,并不是我自己的结论和做实验所得到的结果。我想Michael的实验结果更有说服力一些。本书在github上有中文翻译的…

蓝桥杯每日一题2023.11.23

题目描述 题目分析 本题使用递归模拟即可,将每一个大格子都可以拆分看成几个小格子,先将最开始的数字进行填入,使每一个对应小格子的值都为大格子对应的数,搜索找到符合要求的即可 (答案:50 33 30 41&am…

分布式篇---第二篇

系列文章目录 文章目录 系列文章目录前言一、你知道哪些分布式事务解决方案?二、什么是二阶段提交?三、什么是三阶段提交?前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你…

第十七章:数据库操作

数据库基础 SQL语言 1、select 语句 select 语句用于从数据中检索数据。语法如下: SELECT 搜选字段列表 FROM 数据表名 WHERE 条件表达式 GROUP BY 字段名 HAVING 条件表达式(指定分组的条件) ORDER BY 字段名[ASC|DESC] 2、insert 语句 insert 语句用于向表中插入…

PTA-用天平找小球

三个球A、B、C,大小形状相同且其中有一个球与其他球重量不同。要求找出这个不一样的球。 输入格式: 输入在一行中给出3个正整数,顺序对应球A、B、C的重量。 输出格式: 在一行中输出唯一的那个不一样的球。 输入样例&#xff…

【8】Spring Boot 3 集成组件:安全组件 spring security【官网概念篇】

目录 【8】Spring Boot 3 集成组件:安全组件 spring securitySpring Security 简介先决条件引入依赖身份验证密码存储密码存储历史DelegatingPasswordEncoder密码存储格式密码加解密类自定义密码存储 体系结构 ArchitectureServlet 过滤器DelegatingFilterProxyFilt…

基于element-plus定义表单配置化扩展表单按钮

文章目录 前言一、新增btn.vue组件二、使用总结如有启发&#xff0c;可点赞收藏哟~ 前言 在后台管理系统一般都存在列表查询&#xff0c;且可输入数据进行查询 基于element-plus定义表单配置化 新增按钮配置化 一、新增btn.vue组件 <template><template v-for&qu…

java协程操作mysql数据库

我的项目&#xff1a; nanshaws/nettyWeb: 复习一下netty&#xff0c;并打算做一个web项目出来 (github.com) 最近在项目中分别添加了虚拟线程操作mysql数据库&#xff0c;和用协程操作mysql数据库 同理先跟我这个博客操作一下前面的&#xff1a;就单纯代码的时候进行修改&a…

2014年12月22日 Go生态洞察:Go语言中的代码生成

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

Sui第七轮资助:八个项目共获得超过50万美元的资助

今日&#xff0c;Sui基金会宣布了本月获得资助的项目方&#xff0c;他们将获得超过50万美元的资助金&#xff0c;用于构建项目&#xff0c;推动Sui的采用和发展。要获得资助&#xff0c;项目必须提交提案&#xff0c;详细说明他们正在构建的内容、预算明细、关键里程碑、团队经…

Vue环境的搭建

1.Vue开发的两种方式 &#xff08;1&#xff09;核心包传统开发模式 基于html/css/js文件&#xff0c;直接引入和辛堡&#xff0c;开发Vue。 &#xff08;2&#xff09;工程化开发模式&#xff1a; 主要是基于构建工具&#xff08;例如,webpack&#xff09;的环境中开发Vue…

SpringBoot——感谢尚硅谷官方文档

SpringBoot——感谢尚硅谷官方文档 1 Spring与SpringBoot1、Spring能做什么1.1、Spring的能力1.2、Spring的生态1.3、Spring5重大升级1.3.1、响应式编程1.3.2、内部源码设计 2、为什么用SpringBoot2.1、SpringBoot优点2.2、SpringBoot缺点 3、时代背景3.1、微服务3.2、分布式分…

数据科学导论——数据预处理

第1关:引言-根深之树不怯风折,泉深之水不会涸竭 第2关:数据清理-查漏补缺 import numpy as np import pandas as pd import matplotlib.pyplot as plt def student():train = pd.read_csv(Task1/diabetes_null.csv, na_values=[#NAME?])train[Insulin] = train[Insulin].f…

Linux运行jmeter报错java.sql.SQLException:Cannot create PoolableConnectionFactory

在性能测试过程中遇见1个问题&#xff0c;终于解决了&#xff0c;具体问题如下。 问题 在windows电脑写jmeter脚本连接数据库连接成功 然后把该脚本放到Linux服务器上面&#xff0c;并把jmeter mysql驱动放到服务器上面&#xff0c;修改jmeter的mysql驱动路径信息 注意&…

并行与分布式计算 第9章 算法设计

文章目录 并行与分布式计算 第9章 算法设计9.1 设计过程9.1.1 PCAM设计过程9.1.2 划分9.1.3 通信9.1.4 组合9.1.5 映射 8.2 设计方法8.2.1 划分技术9.2.2 分治9.2.3 平衡树技术9.2.4倍增技术9.2.5 流水线技术9.2.6 破对称技术 并行与分布式计算 第9章 算法设计 9.1 设计过程 …

如何提高图片转excel的效果?(软件选择篇)

在日常的工作中&#xff0c;我们常常会遇到一些财务报表类的图片需要转换成可编辑的excel&#xff0c;但是&#xff0c;受各种条件的限制&#xff0c;常常只能通过手工录入这种原始的方式来实现&#xff0c;随着人工智能、深度学习以及网络技术的发展&#xff0c;这种原始的录入…

一张图,了解美格智能高算力AI模组

美格智能高算力A模组&#xff0c;澎湃算力让AI触手可及&#xff01;

安徽省广德市选择云轴科技ZStack Cloud云平台建设县级智慧城市

信创是数字中国建设的重要组成部分&#xff0c;也是数字经济发展的关键推动力量。作为云基础软件企业&#xff0c;云轴科技ZStack产品矩阵全面覆盖数据中心云基础设施&#xff0c;ZStack信创云首批通过可信云《一云多芯IaaS平台能力要求》先进级&#xff0c;是其中唯一兼容四种…

Pytest模式执行python脚本不生成allure测试报告

1.安装allure 下载allure的zip安装包将allure.zip解压到python的lib目录中将allure的bin路径添加到环境变量path中(注意&#xff1a;配置环境变量后&#xff0c;一定要重启电脑。因为环境变量没生效&#xff0c;我搞了半天在pycharm不能生成报告&#xff0c;在cmd中可以生成报…