队列是一种数据结构,具有先进先出的特点;
队列只允许在队头处出队列,在队尾处进队列;
模拟实现队列可以使用链表或者顺序表来实现,使用链表又可以使用单链表和双向链表来实现,这里我们使用单链表来实现:
public class test {
//设置结点
class Node {
private int val;
private Node next;
private Node(int val){
this.val=val;
}
}
//设置链表的头结点和尾结点
private Node head;
private Node last;
//链表的长度
int UsedSize;
//入队
public boolean offer(int val){
Node node=new Node(val);
//当前链表为空时
if(head==null){
head=node;
last=node;
return true;
}else{
last.next=node; //从队尾入,让链表的为结点指向新的结点
last=last.next; //更新尾结点
UsedSize++; //长度加一
return true;
}
}
//出队
public int poll(){
if(empty()){
System.out.println("队列为空");
return -1;
}else{
int val=head.val; //从队头出,记录当前的头结点的值
head=head.next; //更新头结点
UsedSize--; //长度减一
return val;
}
}
public int peek(){
if(empty()){
System.out.println("队列为空");
return -1;
}else{
int val=head.val;
return val;
}
}
public boolean empty(){
return UsedSize==0;
}
public int getUsedSize(){
return UsedSize;
}
}
java为队列的使用提供了一些方法:

一般比较常用的是上面标红的三个:
public static void main(String[] args) {
Queue<Integer> queue=new LinkedList<>();
//入队
queue.offer(1);
queue.offer(2);
queue.offer(3);
queue.offer(4);
queue.offer(5);
//出队
queue.poll(); // 1
//查看队头元素
queue.peek(); // 2
//队列长度,队列元素个数
queue.size(); // 4
//队列是否为空
queue.isEmpty(); //false
}
public static void main(String[] args) {
Queue<Integer> queue=new LinkedList<>();
//入队
queue.add(5);
queue.add(4);
queue.add(3);
queue.add(2);
queue.add(1);
//出队
Integer t=queue.remove();
System.out.println(t); // 5
//查看队头元素
Integer m=queue.element();
System.out.println(m); // 4
}
这样2组方法实际实现的效果大同小异,但还是有一些细微的差别:
队列的首尾相接的顺序存储结构称为循环队列;
类似就是这样一个结构,front代表队头,rear代表队尾;

由于循环队列首尾相接的特殊性,我们必须考虑到这种队列空和满的情况,不难发现,当front=rear时表示队列为空,但是当队列满时,似乎也是满足这样的条件,因此我们使用一些方法重新来判断队列是空还是满:
public class CircularQueue {
int [] elem;
private int front; //队头元素的下标
private int rear; //队尾元素的下标
//key 数组大小
public CircularQueue(int key){
this.elem=new int[key];
}
//入队
public boolean enQueue(int val){
//判断队列是否满
if(isFull()){
return false;
}
//将元素放到rear下标处
this.elem[rear]=val;
rear=(rear+1)%elem.length;
return true;
}
//出队
public boolean deQueue(){
if (empty()){
return false;
}else{
front=(front+1)%elem.length;
return true;
}
}
//查看队头元素
public int Front(){
if (empty()){
return -1;
}else{
return elem[front];
}
}
//是否队满
public boolean isFull(){
if((rear+1)%elem.length==front){
return true;
}
return false;
}
//是否队空
public boolean empty(){
if (front==rear){
return true;
}
return false;
}
}
over !