青岛大学_王卓老师【数据结构与算法】Week05_13_队列的顺序表示和实现1_学习笔记

本文是个人学习笔记,素材来自青岛大学王卓老师的教学视频。

一方面用于学习记录与分享,

另一方面是想让更多的人看到这么好的《数据结构与算法》的学习视频。

如有侵权,请留言作删文处理。

课程视频链接:

数据结构与算法基础--第05周13--3.5队列的表示和实现2--3.5.2队列的顺序表示和实现1

📚 【Week05】13_队列的顺序表示和实现1

队列

顺序队列空栈、入队和出队示意图

❓ 思考:存在什么问题??

设数组大小为 MAXQSIZE,rear = MAXQSIZE 时,发生溢出。

解决假上溢的方法

(1) 将队中元素依次向队头方向移动。

缺点:浪费时间。每移动一次,队中元素都要移动。

(2) 将队空间设想成一个循环的表,即分配给队列的 m 个存储单元可以循环使用。

当 rear 为 maxqsize 时,若向量的开始端空着,又可从头使用空着的空间。

当 front 为 maxqsize 时,也是一样。

就好像下标为 0 的位置是接在下标为 5 的位置后面。

😊 解决假上溢的方法------引入循环队列

base[0] 接在 base[MAXQSIZE - 1] 之后,若 rear + 1 == M,则令 rear = 0;

实现方法:

利用 模运算(mod,C语言中:%)。

插入元素:

c++ 复制代码
Q.base[Q.rear] = x;
Q.rear = (Q.rear + 1) % MAXQSIZE;

删除元素:

c++ 复制代码
x = Q.base[s.front];
Q.front = (Q.front + 1) % MAXQSIZE;

循环队列:循环使用为队列分配的存储空间。

循环队列入队和出队

❓ 思考:循环队列时会出现队空:front == rear,队满:front == rear,如何判断队空和队满?

解决方案:

(1) 另外设一个标志以区别队空和队满

(2) 另设一个变量,记录元素个数

(3) 少用一个元素空间

循环队列解决队满时判断方法------少用一个元素空间

相关推荐
超级大只老咪6 小时前
快速进制转换
笔记·算法
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.9 小时前
Keepalived VIP迁移邮件告警配置指南
运维·服务器·笔记
ling___xi10 小时前
《计算机网络》计网3小时期末速成课各版本教程都可用谢稀仁湖科大版都可用_哔哩哔哩_bilibili(笔记)
网络·笔记·计算机网络
星火开发设计10 小时前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
Gorgous—l10 小时前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
中屹指纹浏览器11 小时前
中屹指纹浏览器底层架构深度解析——基于虚拟化的全维度指纹仿真与环境隔离实现
经验分享·笔记
Hello_Embed11 小时前
libmodbus 移植 STM32(基础篇)
笔记·stm32·单片机·学习·modbus
无聊的小坏坏11 小时前
实习笔记:用 /etc/crontab 实现定期数据/日志清理
笔记·实习日记
香芋Yu11 小时前
【机器学习教程】第04章 指数族分布
人工智能·笔记·机器学习