环形队列是循环队列吗(环形队列是一种什么结构)

环形队列是循环队列吗(环形队列是一种什么结构)作者 小 K 出品 公众号 小 K 算法 ID xiaok365 0 1 故事起源 队列是一种先进先出的数据结构 一般通过数组实现 还需要定义 2 个指针 头指针和尾指针 02 插入和删除 2 1 插入 从队尾 tail 处插入 再将 tail 指针后移 2 2 删除 从队首 head 处取出素 再将 head 指针后移 但数组是定长的 如果多次插入删除 tail 指针就会超出数组范围 而前面其实还是有空间的 所以常用的还是循环队列 03 循环队列 循环其实就是让 head



作者 | 小K

出品 | 公众号:小K算法 (ID:xiaok365)

01

故事起源

队列是一种先进先出的数据结构。


一般通过数组实现。


还需要定义2个指针,头指针和尾指针。


02

插入和删除

2.1

插入

从队尾tail处插入,再将tail指针后移。


2.2

删除

从队首head处取出素,再将head指针后移。


但数组是定长的,如果多次插入删除,tail指针就会超出数组范围,而前面其实还是有空间的,所以常用的还是循环队列。


03

循环队列

循环其实就是让head,tail两个指针在数组内循环移动,当移动到队尾时就跳到队首。


通过取模就可以实现循环。


当head==tail时,即为队空。


当head==(tail+1)%n时,即为队满。如果队列长度为n,则只能装n-1个素,最后一个素要空着。因为如果放入素,tail会和head重合,就无法判断是队空还是队满。


04

双端队列

普通队列只能队首出,队尾进,但有时我们需要队首和队尾都能进出,即双端队列。


4.1

插入

队首插入,则head指针前移;队尾插入,则tail指针后移。


4.2

删除

队首删除,则head指针后移;队尾删除,则tail指针前移。


05

代码实现

实现一个模板,以后可重复利用。

先定义必要的方法和变量。

构造函数

插入

删除

size方法

使用案例

完整代码已放在github,地址:https://github.com/xiaok365/algorithm-cpp/tree/main/deque

06

总结

队列是非常基础且重要的数据结构,双端队列属于队列的升级。很多的算法都是基于队列来实现,例如搜索中的bfs,图论中的spfa,计算几何中的melkman等。队列结构本身很简单,如何使用才是比较难的,一定要深刻理解,以后才能熟练应用到不同的模型中。

不代表中科院物理所立场

如需转载请联系原公众号

来源:小k算法

编辑:just_iu

1.

2.

3.

4.

5.

6.

7.

8.

9.

今天的文章 环形队列是循环队列吗(环形队列是一种什么结构)分享到此就结束了,感谢您的阅读。
编程小号
上一篇 2025-04-22 08:17
下一篇 2025-06-03 12:51

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/bian-cheng-ri-ji/57670.html