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、输出队列操作

相关推荐
吃着火锅x唱着歌15 小时前
LeetCode 1128.等价多米诺骨牌对的数量
算法·leetcode·职场和发展
ᐇ95916 小时前
Java HashMap深度解析:数据结构、原理与实战指南
java·开发语言·数据结构
十八岁讨厌编程16 小时前
【算法训练营 · 补充】LeetCode Hot100(中)
算法·leetcode
橘颂TA16 小时前
【剑斩OFFER】算法的暴力美学——最小覆盖字串
算法·c/c++·就业
wearegogog12316 小时前
基于混合蛙跳算法和漏桶算法的无线传感器网络拥塞控制与分簇新方法
网络·算法
Tiandaren17 小时前
大模型应用03 || 函数调用 Function Calling || 概念、思想、流程
人工智能·算法·microsoft·数据分析
2301_7951672017 小时前
玩转Rust高级应用 如何进行理解Refutability(可反驳性): 模式是否会匹配失效
开发语言·算法·rust
小当家.10518 小时前
[LeetCode]Hot100系列.贪心总结+思想总结
算法·leetcode·职场和发展
墨雪不会编程18 小时前
数据结构—排序算法篇二
数据结构·算法·排序算法
ShineWinsu19 小时前
对于数据结构:堆的超详细保姆级解析—上
数据结构·c++·算法·计算机·二叉树·顺序表·