【数据结构】--- 栈和队列

前言

        前面学习了数据结构的顺序表、单链表、双向循环链表这些结构;现在就来学习栈和队列,这里可以简单的说栈和队列是具有特殊化的线性表

一、栈

        1.1、栈的概念和结构

        栈是一种遵循先入后出逻辑的线性数据结构。

        栈是一种特殊的线性表,它只允许在固定的一端进行插入和删除元素操作;进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。

        栈中的数据元素遵循先进后出(LIFO)的原则;也就是所谓的后来者居上

        如图所示,我们把堆叠元素的顶部称为“栈顶”,底部称为“栈底”。将元素添加到栈顶的操作叫做“入栈”,删除栈顶的元素叫做“出栈”。

从图中我们可以看出,栈数据的出栈和入栈都在栈顶;这就是栈数据先进后出的原则。

        1.2、栈的实现

        栈的实现可以使用数组来实现,当然也可以使用链表来实现,这里就用数组来实现栈。

用数组来实现栈就和之前顺序表的实现有些相似,对顺序表不了解的话可以看一下前面的

【数据结构】--- 顺序表

首先先来看一下,栈这个数据结构都要实现哪些功能:

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>typedef int SType;
typedef struct Stack
{SType* arr;int size;  //栈顶int num;   //空间大小
}Stack;//初始化
void STInit(Stack* ps);
//判断栈是否为空
bool STEmpty(Stack* ps);
//入栈
void STPush(Stack* ps, SType x);
//出栈
void STPop(Stack* ps);
//取栈顶数据
SType STtop(Stack* ps);
//获取栈中数据个数
int STSize(Stack* ps);
//栈的销毁
void STDesTroy(Stack* ps);

1.2.1、初始化

//初始化
void STInit(Stack* ps)
{assert(ps);ps->arr = NULL;ps->size = ps->num = 0;
}

1.2.2、判断栈是否为空

        判断栈是否为空?如果为空,就返回true;如果不为空,就返回false。

//判断栈是否为空
bool STEmpty(Stack* ps)
{assert(ps);return ps->size == 0;
}

1.2.3、入栈

        入栈,在栈顶插入数据(和顺序表尾插相似)

//入栈
void STPush(Stack* ps, SType x)
{assert(ps);//判断空间大小是否足够if (ps->num <= ps->size){int newnum = (ps->num == 0) ? 4 : 2 * ps->num;SType* tmp = (SType*)realloc(ps->arr, newnum * sizeof(Stack));if (tmp == NULL){perror("realloc filed");exit(1);}ps->arr = tmp;ps->num = newnum;}ps->arr[ps->size++] = x;
}

1.2.4、出栈        

        出栈,删除栈顶的数据(和顺序表尾删相似)

//出栈
void STPop(Stack* ps)
{assert(ps); //不能传NULLassert(!STEmpty(ps));  //栈不能为空ps->size--;
}

1.2.5、取栈顶数据

        取栈顶数据,将栈顶的数据返回即可

//取栈顶数据
SType STtop(Stack* ps)
{assert(ps); //不能传NULLassert(!STEmpty(ps));  //栈不能为空return ps->arr[ps->size - 1];
}

1.2.6、获取栈中数据个数

        获取栈中数据个数,这里size就是栈的数据个数

//获取栈中数据个数
int STSize(Stack* ps)
{assert(ps);return ps->size;
}

1.2.7、销毁栈

        这里,动态开辟的空间要进行释放,养成好习惯

//栈的销毁
void STDesTroy(Stack* ps)
{assert(ps);if (ps->arr)free(ps->arr);ps->arr = NULL;ps->size = ps->num = 0;
}

二、队列

        2.1、队列的概念和结构

        队列,是一种遵循先入先出规则的线性数据结构。

        顾名思义,队列模拟了现实生活中排队现象,即新来的人不断加入队列队尾,而位于对头的人逐个离开

        队列只允许在一端进行插入数据操作,在另一端进行删除数据操作

如图,我们将队列头部称为“对头(队首)”,尾部称为“队尾”;

将把元素插入到队尾操作称为“入队”,删除队首的数据的操作称为“出队”

        2.2、队列的实现

队列的实现,这里也是即可以使用数组来实现,也可以使用链表来实现;这里使用链表来实现队列

 用链表来实现队列就和之前链表的实现有些相似,对单链表不了解的话可以看一下前面的

【数据结构】--- 单链表的实现

        先来卡看队列的基本功能

typedef int QType;
typedef struct QueueNode //队列节结构
{QType data;struct QueueNode* next;
}QueueNode;
typedef struct Queue //队列结构
{int size;   //队列中的数据个数QueueNode* phead; //队头QueueNode* ptial; //队尾
}Queue;//初始化
void QueueInit(Queue* pq);
//判断队列是否为空
bool QueueEmpty(Queue* pq);
//入队列--从队尾删除数据
void QueuePush(Queue* pq);
//出队列--从对头删除数据
void QueuePop(Queue* pq);
//取队头数据
QType QueueFront(Queue* pq);
//取队尾数据
QType QueueBack(Queue* pq);
//获取队列数据个数
int QueueSize(Queue* pq);
//销毁队列
void QueueDesTroy(Queue* pq);

2.2.1、初始化

//初始化
void QueueInit(Queue* pq)
{assert(pq);pq->phead = pq->ptial = NULL;pq->size = 0;
}

2.2.2、判断队列是否为空

        如果队列为空,返回true;如果不为空,返回false

//判断队列是否为空
bool QueueEmpty(Queue* pq)
{assert(pq);return pq->size == 0;
}

2.2.3、入队列

        从队列尾部插入数据,与单链表尾插类似

//入队列--从队尾插入数据
void QueuePush(Queue* pq, QType x)
{assert(pq);QueueNode* newnode = (QueueNode*)malloc(sizeof(QueueNode));newnode->data = x;newnode->next = NULL;if (QueueEmpty(pq)) // 队列为空{pq->phead = pq->ptial = newnode;}else {  //队列不为空pq->ptial->next = newnode;pq->ptial = newnode;}pq->size++;
}

2.2.4、出队列

        从队头删除数据,与链表头删类似

//出队列--从对头删除数据
void QueuePop(Queue* pq)
{assert(pq);  //不能传NULLassert(!QueueEmpty(pq));  //队列不能为空QueueNode* del = pq->phead;pq->phead = pq->phead->next;if (pq->size == 1)  //队列只有一个节点{pq->ptial = NULL;}pq->size--;free(del);del = NULL;
}

2.2.5、取队头数据

        取队头的数据返回

//取队头数据
QType QueueFront(Queue* pq)
{assert(pq);  //不能传NULLassert(!QueueEmpty(pq));  //队列不能为空return pq->phead->data;
}

2.2.6、取队尾数据

        取队尾数据返回

//取队尾数据
QType QueueBack(Queue* pq)
{assert(pq);  //不能传NULLassert(!QueueEmpty(pq));  //队列不能为空return pq->ptial->data;
}

2.2.7、获取队列数据个数

        获取队列数据个数,这里实现队列时,定义了一个结构体成员size记录队列数据个数。

//获取队列数据个数
int QueueSize(Queue* pq)
{assert(pq);  //不能传NULLreturn pq->size;
}

2.2.8、销毁队列

        队列是由链表实现的,而链表是动态开辟的内存,记得释放。

//销毁队列
void QueueDesTroy(Queue* pq)
{assert(pq);  //不能传NULLassert(!QueueEmpty(pq));  //队列不能为空QueueNode* pcur = pq->phead;while (pcur){QueueNode* del = pcur;pcur = pcur->next;free(del);del = NULL;}pq->phead = pq->ptial = NULL;pq->size = 0;
}

感谢各位大佬支持并指出问题,

                        如果本篇内容对你有帮助,可以一键三连支持以下,感谢支持!!!

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

表格竖向展示

最近在做手机端web页面&#xff0c;页面中需要有个表格来显示数据&#xff0c;但是由于数据太多页面太窄&#xff0c;table展示横向滑动的话感觉很丑。所以让表格竖向显示了 具体页面如下: 实现代码&#xff1a;当然代码里面绑定的数据啊什么的你都可以修改为自己的内容&#…

PyTorch高级特性与性能优化

PyTorch高级特性与性能优化 引言&#xff1a; 在深度学习项目中&#xff0c;使用正确的工具和优化策略对于实现高效和有效的模型训练至关重要。PyTorch&#xff0c;作为一个流行的深度学习框架&#xff0c;提供了一系列的高级特性和性能优化方法&#xff0c;以帮助开发者充分利…

TDC 5.0:多集群统一纳管,构建一体化大数据云平台

近期&#xff0c;星环科技数据云平台Transwarp Data Cloud&#xff08;简称TDC&#xff09;5.0版本正式发布&#xff0c;TDC5.0架构屏蔽底层多个TDH集群的差异&#xff0c;采用统一操作模式&#xff0c;新增一个多集群抽象与管理层&#xff0c;能够实现多集群网络互通、跨集群资…

驱动框架——CMSIS第一部分 RTE驱动框架介绍

一、介绍CMISIS 什么是CMSIS&#xff08;cortex microcontrol software interface standard一种软件标准接口&#xff09;&#xff0c;官网地址&#xff1a;https://arm-software.github.io/CMSIS_6/latest/General/index.html 包含的core、driver、RTOS、dsp、nn等部分&…

【MySQL】11.使用 C 语言访问 MySQL

使用C语言访问MySQL 一.检查第三方库是否配置成功二.MySQL 常用接口1.创建&#xff0c;销毁操作句柄2.使用句柄连接数据库3.向 mysqld 发送指令4.查询相关函数 三.使用示例 一.检查第三方库是否配置成功 想要使用代码连接数据库&#xff0c;必须使用 MySQL 官方提供的第三方库。…

redis服务器同 redis 集群

搭建redis服务器 修改服务运行参数 常用命令常用命令 创建redis集群 准备做集群的主机&#xff0c;不允许存储数据、不允许设置连接密码 配置服务器&#xff1a; 1、在任意一台redis服务器上都可以执行创建集群的命令。 2、--cluster-replicas 1 给每个master服务器分配1台…

Java之反射和枚举及lambda表达式

1.反射 1 定义 Java 的反射&#xff08; reflflection &#xff09;机制是在 运行 状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的 所有属性和方法 &#xff1b;对于任 意一个对象&#xff0c;都能够调用它的任意方法和属性&#xff0c;既然能拿到那么&…

链表面试练习习题(Java)

1. 思路&#xff1a; 创建两个链表&#xff0c;一个用来记录小于x的结点&#xff0c;一个用来记录大于等于x的结点&#xff0c;然后遍历完原链表后&#xff0c;将小于x的链表和大于等于x的链表进行拼接即可 public class Partition { public ListNode partition(ListNode pH…

【Java面向对象】抽象类和接口

文章目录 1.抽象类2.常见的抽象类2.1 Number类2.2 Calendar 和GregorianCalendar 3.接口4.常见接口4.1 Comparable 接口4.2 Cloneable 接口4.3 深浅拷贝 5.类的设计原则 1.抽象类 在继承的层次结构中&#xff0c;每个新的子类都使类变得更加明确和具体。如果从一个子类向父类追…

IDEA中创建一个SpringBoot项目并提交到git仓库(日常开发-保姆级手把手超详细截图)

日常开发 第一步&#xff1a; 第二步&#xff1a; &#x1f388;边走、边悟&#x1f388;迟早会好 Git是什么&#xff1f; Git是一款免费、开源的分布式版本控制系统&#xff0c;用于敏捷高效地处理任何或小或大的项目。 Git是一个开源的分布式版本控制系统&#xff0c;可…

【保卫花果山】游戏

游戏介绍 拯救花果山是一款玩家能够进行趣味闯关的休闲类游戏。拯救花果山中玩家需要保护花果山的猴子&#xff0c;利用各种道具来防御妖魔鬼怪的入侵&#xff0c;游戏中玩家需要面对的场景非常的多样&#xff0c;要找到各种应对敌人的方法。拯救花果山里玩家可以不断的进行闯…

[米联客-安路飞龙DR1-FPSOC] FPGA基础篇连载-20 读写I2C接口的RTC时钟芯片

软件版本&#xff1a;Anlogic -TD5.9.1-DR1_ES1.1 操作系统&#xff1a;WIN10 64bit 硬件平台&#xff1a;适用安路(Anlogic)FPGA 实验平台&#xff1a;米联客-MLK-L1-CZ06-DR1M90G开发板 板卡获取平台&#xff1a;https://milianke.tmall.com/ 登录“米联客”FPGA社区 ht…

超声波清洗机选哪款比较好?推荐四款性价比超高型号

2024年的超声波清洗机技术已经取得了显著进步。市面上的超声波清洗机种类繁多&#xff0c;功能各异&#xff0c;有的可以彻底清洁眼镜&#xff0c;有的还能进行消毒等。今天&#xff0c;我向大家推荐几款我亲自测试过的超声波清洗机&#xff0c;它们的性能都相当优秀&#xff0…

分布式搜索引擎ES-elasticsearch入门

1.分布式搜索引擎&#xff1a;luceneVS Solr VS Elasticsearch 什么是分布式搜索引擎 搜索引擎&#xff1a;数据源&#xff1a;数据库或者爬虫资源 分布式存储与搜索&#xff1a;多个节点组成的服务&#xff0c;提高扩展性(扩展成集群) 使用搜索引擎为搜索提供服务。可以从海量…

Android获取当前屏幕显示的是哪个activity

在 Android 中&#xff0c;要获取当前屏幕显示的 Activity&#xff0c;可以使用以下几种方法&#xff1a; 方法一&#xff1a;使用 ActivityManager 获取当前运行的任务信息 这是一个常见的方法&#xff0c;尽管从 Android 5.0 (API 21) 开始&#xff0c;有些方法变得不太可靠…

Java语言程序设计——篇五(2)

有关数组的方法 &#x1f4a5;增强的for循环实战演练 数组元素的复制实战演练 数组参数与返回值&#x1f4a2;java.util.Arrays类数组的排序实战演练 元素的查找数组元素的复制填充数组元素数组的比较实战演练 &#x1f4a5;增强的for循环 增强的for循环&#xff0c;它是Java …

MySQL(6)内置函数,复合查询.

目录 1.内置函数; 2.复合查询; 1.内置函数: 1.1 日期函数: 时分秒: 时间戳: 基本日期上加日期: 基本日期减去日期: 日期相差天数: &#x1f330; 创建一张表&#xff0c;记录生日: 创建一个留言表: 显示所有留言信息&#xff0c;发布日期只显示日期&#xff0c;不用显示时间: …

tree组件实现折叠与展开功能(方式1 - expandedTree计算属性)

本示例节选自vue3最新开源组件实战教程大纲&#xff08;持续更新中&#xff09;的tree组件开发部分。考察响应式对象列表封装和computed计算属性的使用&#xff0c;以及数组reduce方法实现结构化树拍平处理的核心逻辑。 实现思路 第一种方式&#xff1a;每次折叠或展开后触发…

node管理工具nvm

使用nvm可以切换node版本、命令安装node 一、nvm下载安装 1、下载 nvm-setup.zip - 蓝奏云 在github可以选择最新版的【nvm】&#xff1a;&#xff08;nvm-windows 最新下载地址&#xff09;Releases coreybutler/nvm-windows GitHub nvm-noinstall.zip&#xff1a; 这个…

基于edk2编译arm64版intel网卡undi驱动

本文介绍如何在edk2下面编译intel undi驱动。 edk2版本edk2-stable202305 文章目录 一、源码下载二、驱动编译2.1 第一次编译IntelXGigUndi及修改2.2 Intel其他undi驱动编译三、驱动二进制文件四、驱动使用方法一、源码下载 intel 网卡驱动下载地址 https://www.intel.com/con…