【C语言】实现栈


目录

(一)栈

(二)头文件 

(三)功能实现

(1)初始化栈

(2) 栈的销毁

(3)压栈

(4) 出栈

(5) 取出栈顶元素

(6)判断栈是否为空

(7)得到栈的数据个数


正文开始:

(一)栈

        栈是一种常见的数据结构,遵循“后进的数据先出”(Lsat In First Out)的原则。

        栈有两个主要的操作:入栈和出栈。入栈(push)操作将一个元素添加到栈的顶部,而出栈(pop)操作则将栈顶的元素移除。

        栈可以用于解决各种问题,例如实现函数调用栈、表达式求值、回溯算法等。在计算机内存中,栈也常用于存储函数的局部变量、函数调用的上下文信息以及程序的返回地址等。

        栈通常可以使用数组或链表等数据结构来实现。

        使用数组实现的栈称为顺序栈,它具有固定大小的容量;

        而使用链表实现的栈称为链式栈,它可以动态地增长和缩小。

        除了入栈和出栈操作,栈还可以提供其他常见的操作,如获取栈顶元素(top)和判空(isEmpty)。此外,还可以通过计算栈的长度来得知栈中元素的数量。

        

(二)头文件 

         本文根据Cpp的STL来实现栈的相关功能:包括栈的初始化,销毁,压栈,出栈,得到栈顶元素,判断栈是否为空,得到栈内元素个数等共七个功能。

        头文件如下:

        命名:Stack.h

         栈可以用顺序表实现,也可以用链表实现(由于单链表尾插效率低,所以用单链表的头作为栈顶);

        本文基于顺序表实现栈;

#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
#include<assert.h>
//栈数据类型
typedef int StackDatatype;

//一个栈
typedef struct Satck
{
	StackDatatype* a;
	int top;
	int capacity;
}SK;
//初始化
void STInit(SK* st);

//销毁
void STDestory(SK* st);

//压栈
void STPush(SK* st,StackDatatype x);

//出栈
void STPop(SK* st);

//取出栈顶元素
StackDatatype STTop(SK* st);

//栈是否空
bool STEmpty(SK* st);

//得到栈的数据个数
int STSize(SK* st);

(三)功能实现

(1)初始化栈

初始化栈

        首先函数接收的指针不为空(否则无法解引用),通过assert断言完成;

        顺序表数组置空,容量(capacity)和栈顶下一个元素的下标(top)都为0(top表示栈顶元素的下一个元素的下标,top==0表示此时栈内没有任何元素);


//初始化
void STInit(SK* st)
{
	assert(st);

	st->a = NULL;
	st->capacity = st->top = 0;
}

(2) 栈的销毁

 销毁栈

        首先函数接收的指针不为空(否则无法解引用),通过assert断言完成;

        顺序表动态申请的数组释放掉,并置空;

        容量和栈顶元素都置0;


//销毁
void STDestory(SK* st)
{
	assert(st);
	st->capacity = st->top = 0;
	free(st->a);
	st->a = NULL;
}

(3)压栈

         由于栈基于顺序表实现,所以需要判断顺序表是否已经满了,如果栈顶下一个元素的下标等于此时容量,表明栈已满,需要扩容;

        Newcapacity的赋值通过三目操作符实现:如果capacity为初始值0,Newcapacity赋值为4,否则赋值为2*capacity;

        如果realloc申请失败,打印错误信息并返回;

        若申请成功,压入数据;

//压栈
void STPush(SK* st, StackDatatype x)
{
	assert(st);

	if (st->capacity == st->top)
	{
		int Newcapacity = st->capacity == 0 ? 4 : st->capacity * 2;
		StackDatatype* tem = (StackDatatype*)realloc(st->a, sizeof(StackDatatype) * Newcapacity);
		if (tem == NULL)
		{
			perror("realloc fail!");
			return;
		}
		st->a = tem;
		st->capacity = Newcapacity;
	}
	st->a[st->top++] = x;

}

(4) 出栈

        首先函数接收的指针不为空(否则无法解引用),通过assert断言完成;

        其次,栈不为空;

        只需top--,就实现了出栈操作(不需要抹除数据,因为出栈的数据已经无法通过正常方法访问了);


//出栈
void STPop(SK* st)
{
	assert(st);
	assert(!STEmpty(st));

	st->top--;
}

(5) 取出栈顶元素

        首先函数接收的指针不为空(否则无法解引用),通过assert断言完成;

        其次,栈不为空;

        直接返回栈顶元素(top是栈顶元素的下一个元素的下标);

//取出栈顶元素
StackDatatype STTop(SK* st)
{
	assert(st);
	assert(!STEmpty(st));

	return st->a[st->top-1];
}

(6)判断栈是否为空

        首先函数接收的指针不为空(否则无法解引用),通过assert断言完成;

        这里返回判断表达式的值,表达式成立值为真(1),否则值为假(0);【这是很巧妙的写法】


//栈是否空
bool STEmpty(SK* st)
{
	assert(st);
	return st->top == 0;
}

(7)得到栈的数据个数

         首先函数接收的指针不为空(否则无法解引用),通过assert断言完成;

        返回数据个数(下标从0开始,数据个数就是栈顶元素下一个元素的下标);


//得到栈的数据个数
int STSize(SK* st)
{
	assert(st);
	return st->top;
}

 


完~

未经作者同意禁止转载 

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

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

相关文章

MATLAB知识点:unifrnd函数(★★★☆☆)生成任意区间内均匀分布的随机数

​讲解视频&#xff1a;可以在bilibili搜索《MATLAB教程新手入门篇——数学建模清风主讲》。​ MATLAB教程新手入门篇&#xff08;数学建模清风主讲&#xff0c;适合零基础同学观看&#xff09;_哔哩哔哩_bilibili 节选自第3章&#xff1a;课后习题讲解中拓展的函数 在讲解第…

Vue3高频知识点和写法

一 Vue插件 二 vue3项目创建 创建完成后npm install npm run dev 三 setup 一 响应式数据 setup函数是用来代替data和methods的写法的&#xff0c;在setup函数中声明的数据和函数&#xff0c;导出后可以在页面中使用。 但是暂时不是响应式数据&#xff0c;如果要响应式数据的…

2023年03月CCF-GESP编程能力等级认证C++编程二级真题解析

一、单选题(每题2分,共30分) 第1题 以下存储器中的数据不会受到附近强磁场干扰的是( )。 A.硬盘 B.U盘 C.内存 D.光盘 答案:D 第2题 下列流程图,属于计算机的哪种程序结构?( )。 A.顺序结构 B.循环结构 C.分支结构 D.数据结构 答案:C 第3题 下列关…

CVE-2023-22602 漏洞复现

CVE-2023-22602 简述&#xff1a; 由于 1.11.0 及之前版本的 Shiro 只兼容 Spring 的ant-style路径匹配模式&#xff08;pattern matching&#xff09;&#xff0c;且 2.6 及之后版本的 Spring Boot 将 Spring MVC 处理请求的路径匹配模式从AntPathMatcher更改为了PathPatter…

【数据结构】11 堆栈(顺序存储和链式存储)

定义 可认为是具有一定约束的线性表&#xff0c;插入和删除操作都在一个称为栈顶的端点位置。也叫后入先出表&#xff08;LIFO&#xff09; 类型名称&#xff1a;堆栈&#xff08;STACK&#xff09; 数据对象集&#xff1a; 一个有0个或者多个元素的有穷线性表。 操作集&#…

【医学知识图谱 自动补全 关系抽取】生成模型 + 医学知识图谱 = 发现三元组隐藏的关系实体对

生成模型 医学知识图谱 发现三元组新关系实体对 提出背景问题&#xff1a;如何自动发现并生成医疗领域中未被标注的实体关系三元组&#xff1f;CRVAE模型 提出背景 论文&#xff1a;https://dl.acm.org/doi/pdf/10.1145/3219819.3220010 以条件关系变分自编码器&#xff08;…

【51单片机】定时器(江科大)

7.1定时器 1.定时器介绍: 51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成 2. 定时器作用: (1)用于计时系统,可实现软件计时,或者使程序每隔一固定时间完成一项操作 (2)替代长时间的Delay,提高CPU的运行效率和处理速度 定时器在单片机内部就像一个…

模型 “焦糖布丁”理论

系列文章 主要是 分享 思维模型&#xff0c;涉及各个领域&#xff0c;重在提升认知。关注需求本质。 1 “焦糖布丁”理论的应用 1.1 “焦糖布丁”理论-海底捞的创新 海底捞以其优质的服务而闻名&#xff0c;它的成功之处在于深刻理解了消费者的需求和任务&#xff0c;并提供了…

【运维测试】测试理论+工具总结笔记第1篇:测试理论的主要内容(已分享,附代码)

本系列文章md笔记&#xff08;已分享&#xff09;主要讨论测试理论测试工具相关知识。Python测试理论的主要内容&#xff0c;掌握软件测试的基本流程&#xff0c;知道软件测试的V和W模型的优缺点&#xff0c;掌握测试用例设计的要素&#xff0c;掌握等价类划分法、边界值法、因…

React18原理: 时间分片技术选择

渲染1w个节点的不同方式 1 &#xff09;案例1&#xff1a;一次渲染1w个节点 <div idroot><div><script type"text/javascript">function randomHexColor() {return "#" ("0000" (Math.random() * 0x1000000 << 0).toS…

【51单片机】蜂鸣器(江科大)

11.1蜂鸣器 1.蜂鸣器介绍 蜂鸣器是一种将电信号转换为声音信号的器件,常用来产生设备的按键音、报警音等提示信号 蜂鸣器按驱动方式可分为有源蜂鸣器和无源蜂鸣器 有源蜂鸣器:内部自带振荡源,将正负极接上直流电压即可持续发声,频率固定 无源蜂鸣器:内部不带振荡源,需…

【MATLAB】小波神经网络回归预测算法

有意向获取代码&#xff0c;请转文末观看代码获取方式~也可转原文链接获取~ 1 基本定义 小波神经网络回归预测算法是一种利用小波变换和人工神经网络相结合的方法&#xff0c;用于解决回归预测问题。下面将详细介绍该算法的原理与方法&#xff1a; 小波变换&#xff1a; 小波变…

Codeforces Round 924 (Div. 2)

Codeforces Round 924 (Div. 2) Codeforces Round 924 (Div. 2) A. Rectangle Cutting 题意&#xff1a;给出a*b的矩形&#xff0c;沿着其中一个边恰好一分为二后可以组成一个新的矩形 思路&#xff1a;判断其中一个边是否可以被2整除以及二分后是否等于另一个边即可 AC cod…

C++进阶(十六)特殊类设计

&#x1f4d8;北尘_&#xff1a;个人主页 &#x1f30e;个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上&#xff0c;不忘来时的初心 文章目录 一、请设计一个类&#xff0c;不能被拷贝二、请设计一个类&#xff0c;只能在堆上创建对象三、…

腾讯云幻兽帕鲁服务器配置怎么选择合适?

腾讯云幻兽帕鲁服务器配置怎么选&#xff1f;根据玩家数量选择CPU内存配置&#xff0c;4到8人选择4核16G、10到20人玩家选择8核32G、2到4人选择4核8G、32人选择16核64G配置&#xff0c;腾讯云百科txybk.com来详细说下腾讯云幻兽帕鲁专用服务器CPU内存带宽配置选择方法&#xff…

8868体育助力西甲最新积分榜 皇马4球大胜稳坐榜一

西甲联赛第24轮的四场比赛于2月10日全面收官。其中&#xff0c;皇马在主场迎战吉罗纳队&#xff0c;以4-0的大比分击败对手&#xff0c;将领先优势扩大到5分&#xff0c;稳坐西甲榜首&#xff0c;掌握了争冠的主动权。 威尼修斯的世界波为皇马打开胜利之门&#xff0c;第6分钟就…

侧信道攻击是什么

侧信道攻击是什么? 侧信道攻击是一种利用系统的物理实现或实现的特定属性来获取信息的攻击方式。这些攻击利用了系统在执行特定操作时产生的信息泄漏&#xff0c;而不是直接攻击系统的计算或加密算法。侧信道攻击通常利用系统的功耗、电磁辐射、时间延迟等物理特性进行攻击&a…

Python实现MACD指标计算:股票技术分析的利器系列(1)

Python实现MACD指标计算&#xff1a;股票技术分析的利器系列&#xff08;1&#xff09; 介绍核心代码&#xff1a;EMA核心代码&#xff1a;MACD200 次交易日的收盘价格完整代码最终运行代码的效果展示DIFDEAMACD 介绍 先看看官方介绍&#xff1a; MACD (平滑异同平均线&#x…

Linux——进程间通信:管道

我们在开发过程中&#xff0c;可能会碰到两个或多个进程需要协同进行&#xff0c;这两个进 程之间有着一定的关系&#xff0c;这个进程可能会需要另一个进程的某些消息来达 到自己的目的&#xff0c;或者是一个进程控制着另一个进程&#xff0c;又或者是需要某种资 源的共享。但…

BFS与DFS初级练习(排列数字,n-皇后,走迷宫)

BFS与DFS初步了解 DFS&#xff08;深度优先搜索&#xff09;和BFS&#xff08;广度优先搜索&#xff09;是两种常用的图遍历算法。 DFS是一种递归的搜索算法&#xff0c;它从起始节点开始&#xff0c;沿着路径依次访问与当前节点相邻的未访问节点&#xff0c;直到无法继续访问…