线性数据结构之队列(Queue)

简介: 队列是一种用来存储数据的数据结构 , 与链表和栈类似 , 数据到达的次序是队列的关键 , 类似于生活中我们在排队购买东西时 , 第一个人是队首 , 最后一个人是队尾 , 第一个人先买到东西后离开 , 这个时候第二个人便成了队首 , 以此类推…

一.队列(Queue)

队列是一种用来存储数据的数据结构 , 与链表和栈类似 , 数据到达的次序是队列的关键 , 类似于生活中我们在排队购买东西时 , 第一个人是队首 , 最后一个人是队尾 , 第一个人先买到东西后离开 , 这个时候第二个人便成了队首 , 以此类推…


队列中第一个插入的元素也是第一个被删除的元素 , 所以队列是一种先进先出(First In First Out 简称 FIFO)或者后进后出(Last In Last Out 简称 LILO)的线性表


队列是一种只能在一端(队尾)插入 , 另一端(队首)删除的有序线性表 , 在队列中插入一个元素被称为入队(EnQueqe) , 在队列删除一个元素被称为出队(DeQueuq) , 试图对一个空队列执行出栈操作 , 被称为下溢(underflow) , 试图对一个满队列执行入队操作 , 被称为溢出(overflow)


d56038c312130409c51d2ba238959823_93bc6836897035fad880f67749ca0903.png


1.队列的实现方式

基于简单循环数组实现


基于动态循环数组实现


基于链表的方式实现


1.1 基于简单循环数组实现

79f3b7d38689250f16d02ddaf4ee52f5_f0d3bf532454b587d8cbac7787bdaa3b.png


通常将尾指针rear指向当前队尾元素的真正位置 , 而头指针front指向当前队头元素的前一个位置(不让队头指针 , 队尾指针指向真正的元素是为了运算的时候方便 , 并不是唯一的方法) , 刚开始时 , 队列的头 , 尾指针都为-1 , 后面在出队或者入队时 , 头指针和尾指针值递增变化 , 如上图所示


如果队列为空的时候进行出队操作 , 那么此时将产生下溢现象 , 相反 , 如果队列满时做入队操作将会出现上溢现象


出栈和出队并不是真正的删除元素 , 只是不起作用


时间复杂度

入栈操作EnQueue时间复杂度为O(1)


出栈操作DeQueue时间复杂度为O(1)


局限性

用于实现队列的数组的最大空间必须预先声明且不能改变。试图对一个满队列执行入队操作会产生一个针对简单数组这种特定实现队列方式的异常。


1.2 基于动态循环数组实现

基于动态循环数组实现就是在每次队满的时候进行动态的扩容即可 , 原理同栈一样


栈数据结构飞机票 : 线性数据结构之栈(Stack)


时间复杂度

入队操作EnQueue时间复杂度考虑扩容的情况下为O(N) , 否则为O(1)


出队操作DeQueue时间复杂度为O(1)


1.3 基于链表的实现方式

实现队列的另一种方法是使用链表。通过在链表末端插入元素的方法实现入队(EnQueue)操作。通过删除链表表头元素的方法实现出队操作(DeQueue)。


3ad34bdc3a4b16a14270eefcfa642d97_b10bd7a818c4b8dc38a2dd8cc7060ead.jpeg


时间复杂度

入队操作EnQueue时间复杂度平均为O(1)


出队操作DeQueue时间复杂度为O(1)

相关文章
|
27天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
123 9
|
1月前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
2月前
初步认识栈和队列
初步认识栈和队列
61 10
|
2月前
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
23 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
2月前
【数据结构】-- 栈和队列
【数据结构】-- 栈和队列
17 0
|
2月前
探索数据结构:队列的的实现与应用
探索数据结构:队列的的实现与应用
|
2月前
|
存储 C语言
栈和队列题目练习
栈和队列题目练习
19 0
|
18天前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
23 1
|
6天前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
28 5
|
21天前
|
存储 算法 Java
数据结构的栈
栈作为一种简单而高效的数据结构,在计算机科学和软件开发中有着广泛的应用。通过合理地使用栈,可以有效地解决许多与数据存储和操作相关的问题。