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

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

一、循环队列

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

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 接口是比较多的,栈和队列均可以使用该接口
Deque<Integer> stack = new ArrayDeque<>();//双端队列的线性实现
Deque<Integer> queue = new LinkedList<>();//双端队列的链式实现

三、总结

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


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

相关推荐

  1. 数据结构应用(详解)

    2024-07-14 04:26:02       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-14 04:26:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-14 04:26:02       71 阅读
  3. 在Django里面运行非项目文件

    2024-07-14 04:26:02       58 阅读
  4. Python语言-面向对象

    2024-07-14 04:26:02       69 阅读

热门阅读

  1. 在Spring Boot项目中集成分布式追踪系统

    2024-07-14 04:26:02       29 阅读
  2. 小程序中用于跳转页面的5个api是什么和区别

    2024-07-14 04:26:02       23 阅读
  3. GitHub每日最火火火项目(7.13)

    2024-07-14 04:26:02       20 阅读
  4. QTextEdit 设置宽度

    2024-07-14 04:26:02       24 阅读
  5. redis 夺命21问

    2024-07-14 04:26:02       20 阅读
  6. Gitlab介绍

    2024-07-14 04:26:02       17 阅读
  7. 变分法笔记2

    2024-07-14 04:26:02       21 阅读
  8. 爬虫:Sentry-Span参数逆向

    2024-07-14 04:26:02       20 阅读
  9. android 嵌套webview,软键盘遮挡输入框

    2024-07-14 04:26:02       23 阅读
  10. ref和reactive区别

    2024-07-14 04:26:02       21 阅读
  11. 【随想】闲聊、沟通和谈判

    2024-07-14 04:26:02       20 阅读
  12. nginx防盗链

    2024-07-14 04:26:02       26 阅读
  13. 【C++编程】类的静态 static 成员 & 常 const 函数

    2024-07-14 04:26:02       19 阅读