【数据结构】队列的补充与扩展

上篇文章中我们主要介绍了单向队列的特点与使用。作为补充,这篇文章就让我们来研究一下一些特殊的队列吧。

一、循环队列

实际中我们有时还会使用一种队列叫循环队列。如操作系统课程讲解生产者消费者模型时可以就会使用循环队列。 环形队列通常使用数组实现

1、数组下标循环的小技巧
(1) 下标最后再往后 (offset 小于 array.length): index = (index + offset) % array.length

(2)下标最前再往前(offset 小于 array.length): index = (index + array.length - offset) % array.length

2、如何区分空与满

  1. 通过添加 size 属性记录
  2. 保留一个位置
  3. 使用标记

二、双端队列**(Deque)**

双端队列( deque )是指允许两端都可以进行入队和出队操作的队列, deque 是 "double ended queue" 的简称。那就说明元素可以从队头出队和入队,也可以从队尾出队和入队。


Deque 是一个接口,使用时必须创建 LinkedList 的对象。


在实际工程中,使用 Deque 接口是比较多的,栈和队列均可以使用该接口

java 复制代码
Deque<Integer> stack = new ArrayDeque<>();//双端队列的线性实现
Deque<Integer> queue = new LinkedList<>();//双端队列的链式实现

三、总结

本篇文章主要就是对上篇文章的补充说明,拓宽一下队列的应用方式与应用场景。了解循环队列与双端队列的工作原理与应用方式即可


那么本篇文章就到此为止了,如果觉得这篇文章对你有帮助的话,可以点一下关注和点赞来支持作者哦。作者还是一个萌新,如果有什么讲的不对的地方欢迎在评论区指出,希望能够和你们一起进步✊

相关推荐
2301_7796224113 分钟前
CSS Grid布局如何实现固定页脚效果_利用网格高度视口百分比单位
jvm·数据库·python
m0_7390300014 分钟前
mabatis-plus 和mabatis 的区别
java·数据库·mybatis
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ14 分钟前
判断两个集合是不是相同
java
创意岛15 分钟前
大湾区制造企业品牌突围:从“有品无牌”到价值孵化
python·制造
凌波粒16 分钟前
LeetCode--二叉树层序遍历实战指南
算法·leetcode·职场和发展
是有头发的程序猿16 分钟前
AI Agent自动化交易流程:1688定制交易API全链路开发实战教程(Python源码)
python·自动化·php
yexuhgu17 分钟前
C#怎么实现线程安全的单例_C#如何使用Lazy延迟加载【核心】
jvm·数据库·python
huaiixinsi18 分钟前
Canal + Outbox、Kafka 选型与高可用、Caffeine 底层原理总结
java·数据库·分布式·mysql·spring·adb·kafka
Ting-yu19 分钟前
SpringCloud快速入门(11)---- Sentinel(异常处理)
java·spring boot·后端·spring·spring cloud·sentinel
X566119 分钟前
什么是Bootstrap的移动优先响应式设计
jvm·数据库·python