24.8.9数据结构|链栈和队列

链栈

1、理解

实际上是一个仅在表头进行操作的单链表,头指针指向栈顶结点头结点 ,以下恋栈均指带头结点的链栈.

2、 基本操作

**1、定义结构:**节点含有数据域和指针域

2、初始化操作: 建立一个带头结点的空栈

**3、取栈顶元素操作:**取出栈的栈顶元素,将栈中第一个节点的值送到e所指向的内存单元,不删除栈顶结点

**4、求栈长操作:**从栈顶开始统计栈中元素个数直到栈底为止

**5、入栈操作:**将值为X的数据元素插入栈中使X成为新的栈顶元素

(先创建一个新结点,其数据域的值为X,然后将该结点插入到头节点之后作为栈顶结点)考虑空间申请是否成功

6、出栈操作: 删除S的栈顶元素**(先将栈S的栈顶结点的值送到一所指的内存单元然后删除栈顶结点)考虑栈空**

**7、栈空操作:**判断栈是否为空

**8、输出栈:**输出自栈顶到栈底的元素值

3、代码

4、课后练习

例题1

编写算法利用栈将带头结点的单链表逆置

例题2

设计一个算法判断一个字符串是否对称若是则返回一否则返回零

队列

顺序队列

1、理解

特殊的线性表,只允许在一端插入另一端删除 ,队尾插入队头删除。对头指针和队尾指针并不一定是指针变量,也可以是下标变量。在用下标变量来描述队列时,在初始化空队列时,队头指针和队尾指针的值都为零。当当front==rear时,队列为空,当rear==Maxsize时,队列为满。

入队时尾指针rear加一,出队时头指针front加一

2、基本操作(顺序队列、循环队列)

1、顺序队列的类型定义:基地址、队头指针、队尾指针

2、初始化操作:构建一个空队列

3、求队列长度操作:返回队列的元素个数

4、取队头元素操作:通过一返回队列的队头元素值

**5、入队操作:**将值为X的元素插入到队列中使X成为新的队尾元素

**6、出队操作:**删除队列中的队头元素同时将队头元素值通过E代回,原队列中的第二个元素成为新的队头元素。

**7、判断队空操作:**判断队列queue是否为空若队列为空则返回一否则返回零

**8、输出队列操作:**从对头到队尾依次输出队列queue中的所有元素

队列也是一个线性表其存储结构也分为顺序存储和链式序存储两种分别称为顺序队列和链队列

循环队列

1、理解

为了解决入队列操作产生**假溢出现象,**可以把顺序队列从逻辑上看成是一个环,即当队列为指针或队头指针达到最大下标值Maxsize时,再从下标为零的位置开始举,这种队列称为循环队列。、

循环队列中队头指针和队尾指针的后移可以利用除最大下标值取余的运算来实现

队头指针后移操作:

front=(front+1)%MAXQSIZE;

队列长度的计算公式为:

( rear+Maxsize-front)%Maxsize

链式队列

实际上是一个带头指针和尾指针的单链表。

1、结构定义

2、初始化操作

3、求队列长度操作

4、判断队列为空

5、取队头元素

6、入队列操作

7、出队操作

8、输出队列操作

相关推荐
小糯米6017 分钟前
C++顺序表和vector
开发语言·c++·算法
We་ct28 分钟前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
Lionel68933 分钟前
分步实现 Flutter 鸿蒙轮播图核心功能(搜索框 + 指示灯)
算法·图搜索算法
小妖66637 分钟前
js 实现快速排序算法
数据结构·算法·排序算法
xsyaaaan39 分钟前
代码随想录Day30动态规划:背包问题二维_背包问题一维_416分割等和子集
算法·动态规划
zheyutao2 小时前
字符串哈希
算法
A尘埃2 小时前
保险公司车险理赔欺诈检测(随机森林)
算法·随机森林·机器学习
大江东去浪淘尽千古风流人物2 小时前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)
人工智能·python·算法
独好紫罗兰3 小时前
对python的再认识-基于数据结构进行-a003-列表-排序
开发语言·数据结构·python
wuhen_n3 小时前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构