线性队列:线性队列通常称为队列。它是一种遵循 FIFO(先进先出)顺序的线性数据结构。队列的一个现实示例是等待从先到的客户得到服务的商店购买产品的任何客户队列。在队列中,所有删除(出队)都在前端进行,所有插入(入队)都在后端进行。
循环队列:循环队列只是线性队列的一种变体,其中前端和后端相互连接,以优化线性队列的空间浪费并使其高效。
以下操作将说明Circular Queue如何优于Linear Queue :
- 当在两个队列中进行排队的操作:让队列大小6的具有元素{29,21,72,13,34,24}。在两个队列中,第一个元素29处的前点和最后一个元素 24处的后点,如下图所示:
- 当对两个队列都执行Dequeue操作时:考虑从两个队列中删除的前 2 个元素。在两个队列中,元素72处的前点和元素 24处的后点,如下图所示:
- 现在再次执行入队操作:考虑在两个队列中插入值为 100的元素。在Linear Queue 中无法插入元素100 ,但在Circular Queue 中,可以插入值为100的元素,如下图所示:
说明:
- 由于队列中的插入来自后端,并且在固定大小的线性队列的情况下,当后端到达队列末尾时,无法插入。
- 但是在 Circular Queue的情况下,后端从最后一个位置循环移动到前面位置。
结论:循环队列比线性队列有更多的优势。循环队列的其他优点是:
- 更容易插入-删除:在循环队列中,如果有空位置,元素可以很容易地插入,直到它没有被完全占用,而在线性队列的情况下,一旦尾部到达最后一个索引,即使有是队列中存在的空位置。
- 内存的高效利用:在循环队列中,不会浪费内存,因为它使用了未占用的空间,与线性队列相比,内存以有价值和有效的方式被正确使用。
- 易于执行:在线性队列中,遵循FIFO ,因此首先插入的元素是最先删除的元素。这不是循环队列的情况,因为后端和前端不是固定的,因此可以更改插入删除的顺序,这非常有用。
如果您想与行业专家一起参加直播课程,请参阅Geeks Classes Live