C语言数据结构——第三章 栈和队列
三、栈和队列
栈和队列是两种重要的线性结构。从数据结构的角度来看,栈和队列也是线性表,它的特殊性在于栈和队列的基本操作是线性表操作的子集,它们的操作相对于线性表来说是受到限制的,因此,可以称其为限定性的数据结构。
从数据类型的角度看,它们是和线性表大不相同的两种重要的抽象数据类型,在面向对象的程序设计中,它们是多型数据类型。
3.1-栈
3.1.1-抽象数据类型栈的定义
栈:是限定仅在表尾进行插入或删除操作的线性表,又可以称为后进先出的线性表。
栈顶:栈的表尾端
栈底:栈的表头端
空栈:不含元素的空表
3.1.2-栈的表示和实现
和线性表相似,栈也有两种存储表示方法,即顺序栈和链栈。
(1)栈的顺序存储
所谓栈的顺序存储,就是采用一组物理上连续的存储单元来存放栈中所有元素,并使用top指针来指示当前栈中处于栈顶的元素。
(1.1) 顺序栈的基本操作:
-1:初始化栈函数的实现
- 对栈空间进行初始化
- 对栈顶指针进行初始化
-2:判断栈是否为空的函数实现
- 将当前栈顶指针的值与之前初始化的设置的栈顶指针的值相比较
- 若两者相等,则表示当前栈为空,否则表示当前栈不为空
-3:进栈函数的实现
- 判断当前栈是否有剩余空间
- 若当前栈未满,修改栈顶指针的值,使其指向栈的下一个空闲位置
- 将要进栈的元素放在上述空闲位置,进栈操作完成
- 若栈满则表示没有空间,无法进行栈操作
-4:出栈函数的实现
- 判断栈是否为空,若为空则无法进行出栈操作,给出栈为空的提示
- 若栈不为空,则记下当前栈顶指针的值
- 修改栈顶指针的值,使其指向出栈元素的下一个元素
- 返回第二步中记下的栈顶指针的值对应栈中的元素
-5:获取栈顶元素函数的实现
- 判断当前栈是否为空
- 若当前栈为空,则无法获取任何栈顶元素,词是给出栈为空的提示,并结束操作
- 若不为空,则返回栈顶元素
-6:遍历栈内元素函数的实现
- 判断栈是否为空,若为空,则栈内没有元素可以访问,此时给出栈为空的提示
- 若栈不为空,则从栈底到栈顶依次访问栈中元素
-7:通过用户输入数据的方式创建一个顺序栈
- 接收用户输入
- 若用户输入的是空,则算法结束,否则执行下一步
- 将用户输入的元素进栈
(2)栈的链式存储
栈的顺序存储通常要求系统分配一组连续的存储单元,在实现时,对于某些语言而言,当栈满后想要增加连续的存储空间时无法实现的。我们可以通过链式存储来实现需要多少存储空间就申请多少存储空间,这减低空间使用的浪费率。
(2.1)链栈的基本操作
-1:初始换链栈函数的实现
- 创建一个链栈结点
- 使用该结点对栈顶指针进行初始化
-2:判断链栈是否为空函数的实现
- 判断指示栈顶的结点的指针域是否为空
- 若上一步为真,则表示当前栈为空,否则表示当前栈不为空
-3:进栈函数的实现
- 创建一个新的结点,并将待进栈的元素存入该结点的数据域中
- 将新的结点的指针域指向栈顶结点指针与指向的结点
- 将栈顶结点的指针域指向新的结点
-4:出栈函数的实现
- 判断栈是否为空
- 若第一步为真,则无法执行元素出栈操作,此时给出栈为空的提示,否则执行
- 记下此时的栈顶结点指针域指向的结点
- 修改栈顶结点的指针域,在其中存入第三步记下的结点指针域的值
- 将data域值为da的结点出栈
-5:获取栈顶元素函数的实现
- 判断栈是否为空
- 若第一步为真,则执行第三步,否则执行第四步
- 给出栈为空的提示并返回
- 返回栈顶元素的值
-6:通过用户输入的方式创一个链栈
- 接收用户输入
- 若第一步未结束标志,则算法结束,否则执行下一步
- 将用户输入的元素进栈
3.2-队列
与栈一样,队列也是一种特殊的线性表,不同的是,队列在进行数据操作是必须遵循“先进先出”的原则,这一特点决定了队列的进本操作需要在其两端进行。
3.2.1-队列的基本概念
队列的基本操作通常在队列两端被执行,其中执行插入元素操作的一端被称为队尾;执行删除元素操作的一段被称为队头。队列中的元素个数就是队列的长度,若队列中不包含任何元素,则被称为队空,若队列中没有可用空间存储待进队元素,此时我们称为队满。
3.2.2-队列的顺序存储
队列的顺序存储是指采用一组物理上连续的存储单元来放队列中的所有元素。为了便于计算队列中的元素个数,我们约定,队头指针指向实际队头元素所在位置的前一位置,对位指针指向实际队尾元素所在的位置。
3.2.3-顺序队列的基本操作
(1)初始化队列函数的实现
- 对队列空间进行初始化
- 对队头指针进行初始化
- 对队尾指针进行初始化
(2)判断队列是否为空函数的实现
- 将队头指针的值与队尾指针的值相比较
- 若两者相等则表示当前队列为空,否则表示当前队列不为空
(3)元素进队函数的实现
- 判断当前队列是否有剩余空间
- 若当前队列未满,修改队尾指针的值,使其指向队列的下一个空闲位置
- 将要进对的元素放在上述空闲位置,进队操作完成
- 若队满,则表示没有空间用于执行进队操作
(4)元素出队函数的实现
- 判断队列是否为空,若队空则无法执行出队操作,并提示队列为空
- 若队列不为空,则修改队头指针的值,使其指向待出队元素
- 返回待出队元素
(5)获取队头元素的实现
- 判断当前队列是否为空
- 若第一步为真,则无法获取任何队头元素,此时给出队列为空的提示,并结束操作,否则执行下一步
- 返回当前队头元素
(6)通过用户输入数据的方式创建一个顺序队列
- 接收用户输入
- 若第一步为结束标志,则算法结束;否则执行下一步
- 将用户输入的元素进队
3.2.4-循环顺序队列的基本操作
(1)元素进队函数的实现
- 判断当前队列是否有剩余空间
- 若当前队列未满,则修改队尾指针的值,使其指向队列的下一个空闲位置
- 将要进队的元素放在上述空闲位置,进队操作完成
- 若队满,则表示没有空闲用于执行进队操作
(2)元素出队函数的实现
- 判断队列是否为空
- 若第一步为真,则无法执行出队操作,提示队列为空并返回,否则执行下一步
- 修改队头指针的值使其指向待出队元素
- 返回待出队元素
(3)通过用户输入的方式创建一个循环顺序队列
- 接收用户输入
- 若第一步为结束标志,则算法结束,否则执行下一步
- 将用户输入的数据元素进队
3.2.5-队列的链式存储
1.链式存储的基本操作
(1)创建链式队列函数的实现
- 创建一个新的结点
- 初始化队头指针使其指向新结点
- 初始化队尾指针使其指向新结点
(2)判断队头指针和队尾指针是否为空函数的实现
- 判断队头和队尾指针是否相等
- 若相等则表示当前队列为空,否则表示当前队列不为空
(3)进队函数的实现
- 创建一个新的结点,并将待进队的元素存入该结点的数据域中
- 将结点的地址存入队尾指针指向的结点的指针域中
- 将队尾指针指向新结点
(4)出对函数的实现
- 判断队列是否为空,若队列为空,则无法执行出队操作,此时给出队列为空的提示,否则执行下一步
- 鸡下队头指针指向的结点的下一个结点
- 修改队头指针指向的结点的指针域,在其中存入第二步中记下结点的指针域的值
- 判断队尾指针所在结点是否相等域第二部中记下的结点
- 若第四步为真,则修改队尾指针,将其指向队头指针指向的结点
- 返回出对元素
(5)获取队头元素函数的实现
- 判断队列是否为空
- 若第一步为真,则无法获取队头元素,提示队列为空,并结束操作;否则执行下一步
- 返回队头元素的值
(6)通过用户输入数据的方式创建一个队列
- 接收用户的输入
- 若第一步为结束标志,则算法结束,否则执行下一步
- 将用户输入的数据元素进队。
2.循环链式队列
循环链式队列是将链式队列的队尾指针所在的结点指向头结点。由于头结点的下一个结点就是队头元素所在得到位置,而队尾指针所在的结点又指向头结点,所以由队尾指针也可以找到队头元素,因此在循环链式队列中我们不需要再增设队头指针。
3.3-递归
3.3.1-什么是递归
递归是数学中一个十分重要的概念,它也被大量应用在计算技术中,其特征为直接或间接调用自身,我们通常把一函数调用自身称为递归,否则称为间接递归。在算法设计中,任何间接递归都可以转化为直接递归来实现。
C语言数据结构——第三章 栈和队列的更多相关文章
- PTA 第三章 栈与队列
一.判断题 1.若一个栈的输入序列为1,2,3,--,N,输出序列的第一个元素为i,则第j个输出的元素是j-i-1 (×)解析:应该是不确定的,不能保证数字出栈后不会再入栈 2.所谓" ...
- C语言数据结构基础学习笔记——栈和队列
之前我们学过了普通的线性表,接下来我们来了解一下两种特殊的线性表——栈和队列. 栈是只允许在一端进行插入或删除的线性表. 栈的顺序存储结构也叫作顺序栈,对于栈顶指针top,当栈为空栈时,top=-1: ...
- 数据结构(C语言版)---第三章栈和队列 3.4.2 队列的链式表示和实现(循环队列)
这个是循环队列的实现,至于串及数组这两章,等有空再看,下面将学习树. 源码如下: #include <stdio.h> #include <stdlib.h> #define ...
- 数据结构与算法分析——C语言描述 第三章的单链表
数据结构与算法分析--C语言描述 第三章的单链表 很基础的东西.走一遍流程.有人说学编程最简单最笨的方法就是把书上的代码敲一遍.这个我是头文件是照抄的..c源文件自己实现. list.h typede ...
- 数据结构(c语言版,严蔚敏)第3章栈和队列
第3章栈和队列
- java实现 数据结构:链表、 栈、 队列、优先级队列、哈希表
java实现 数据结构:链表. 栈. 队列.优先级队列.哈希表 数据结构javavector工作importlist 最近在准备找工作的事情,就复习了一下java.翻了一下书和网上的教材,发现虽然 ...
- 数据结构(C语言版)-第3章 栈和队列
3.1 栈和队列的定义和特点3.2 案例引入3.3 栈的表示和操作的实现3.4 栈与递归3.5 队列的的表示和操作的实现3.6 案例分析与实现 基本操作有入栈.出栈.读栈顶元素值.建栈.判断栈满.栈空 ...
- 数据结构(三)——栈Stack
栈是一种特殊的线性表,插入和删除操作均在栈顶进行,插入操作称为入栈,删除操作称为出栈. 一.顺序栈 利用顺序存储方式实现的栈称为顺序栈,下面是它的一些基本操作实现算法,需要理解和记忆. 1.顺序栈的类 ...
- 用JS描述的数据结构及算法表示——栈和队列(基础版)
前言:找了上课时数据结构的教程来看,但是用的语言是c++,所以具体实现在网上搜大神的博客来看,我看到的大神们的博客都写得特别好,不止讲了最基本的思想和算法实现,更多的是侧重于实例运用,一边看一边在心里 ...
随机推荐
- Docker最全教程——从理论到实战(十八)
前言 VS Code是一个年轻的编辑器,但是确实是非常犀利.通过本篇,老司机带你使用VS Code玩转Docker——相信阅读本篇之后,无论是初学者还是老手,都可以非常方便的玩转Docker了!所谓是 ...
- C 基础 _Generic 泛型应用
引言 - _Generic 用法简介 #include <stdio.h> #define TYPENAME_CASE(type) \ type: #type, #define TYPEN ...
- mp3格式音频 不能立即播放
原因是mp3的meta信息在mp3文件后面,所以要都加载完才能播放 而m4a 格式的 可以立即播放
- sqlalchemy_mptt一次调优
问题背景: 我用sqlalchemy_mptt构建了一个多级分类项目,数据库用了sqlite.随着数据条数越来越多,写入速度逐渐变慢,一棵树的插入甚至需要1分钟,远远不能满足需求 分析思路: 1. 批 ...
- SVM-支持向量机(二)非线性SVM分类
非线性SVM分类 尽管SVM分类器非常高效,并且在很多场景下都非常实用.但是很多数据集并不是可以线性可分的.一个处理非线性数据集的方法是增加更多的特征,例如多项式特征.在某些情况下,这样可以让数据集变 ...
- Python-Django学习笔记(一)-MTV设计模式
Django是开源的.大而且全的Web应用框架. 它独具特色,采用了MTV设计模式. MTV框架包括:Model(模型).Template(模板)和View(视图) Model(模型):负责业务对象与 ...
- [HAOI2011] Problem b - 莫比乌斯反演
复习一下莫比乌斯反演 首先很显然用一下容斥把它转化成求 \(ans=\sum_{i=1}^a \sum_{j=1}^b [{gcd(i,j)=d}]\) 我们可以定义 f(d) 和 F(d) 如下: ...
- Unable to create initial connections of pool. spring boot mysql
Unable to create initial connections of pool. 在链接url里添加 将useSSL=true改为useSSL=false 只能说明服务器没有打开SSL功能
- IntelliJ IDEA 2019.1.3 最新破解教程【最强 可用至2099年】
本文包括最新[2019.1.2]安装 和[2018.3.2](推荐)安装 ①IntelliJ IDEA 2018.3.2安装永久安装[最强] 一. 在官网下载IDEA安装包 链接:https:// ...
- [MongoDB] 使用PHP在MongoDB中搜索的实现
条件操作符用于比较两个表达式并从mongoDB集合中获取数据.MongoDB中条件操作符有:(>) 大于 - $gt(<) 小于 - $lt(>=) 大于等于 - $gte(< ...