基本概念
队列(Queue)两端同意操作的类型不一样:
能够进行删除的一端称为队头,这样的操作也叫出队dequeue;
能够进行插入的一端称为队尾,这样的操作也叫入队enqueue。
1、添加一个属性size用来记录眼下的元素个数。
目的是当head=rear的时候。通过size=0还是size=数组长度。来区分队列为空,或者队列已满。
2、数组中仅仅存储数组大小-1个元素,保证rear转一圈之后不会和head相等。也就是队列满的时候。rear+1=head,中间刚好空一个元素。
当rear=head的时候。一定是队列空了。
解决这种问题的常见做法是这种:
使用一标记,用以区分这样的易混淆的情形。
牺牲一个元素空间。当front和rear相等时,为空。当rear的下一个位置是front时,为满。
代码实现
1 | package com.hyh.datastructure; |