3.队列
3.1队列介绍
- 队列是一个有序列表,可以用数组或者是链表来实现
- 遵循先入先出原则。
- 示意图:
3.2数组模拟队列思路
代码实现
package arrayQueue;
import java.util.Scanner;
public class arrayQueueDemo {
public static void main(String[] args) {
ArrayQueue queue = new ArrayQueue(3);
char key = ' '; // 接受用户输入字符
boolean flag = true;
Scanner sc = new Scanner(System.in);
while (flag) {
System.out.println("s: 显示队列");
System.out.println("e: 退出程序");
System.out.println("a: 添加元素");
System.out.println("g: 元素出队列");
System.out.println("h: 查看头元素");
key = sc.next().charAt(0);
switch (key) {
case 's':
queue.showQueue();
break;
case 'a':
System.out.println("请输入一个数");
int val = sc.nextInt();
queue.add(val);
break;
case 'g':
try {
int res = queue.get();
System.out.printf("取出的数据是%d", res);
} catch (Exception e) {
System.out.println(e.getMessage());
}
break;
case 'h':
try {
int res = queue.showHead();
System.out.printf("取出的数据是%d", res);
} catch (Exception e) {
System.out.println(e.getMessage());
}
break;
case 'e':
sc.close();
flag = false;
break;
default:
break;
}
}
System.out.println("程序退出");
}
}
class ArrayQueue {
private int rear;
private int front;
private int maxSize;
private int[] arr;
public ArrayQueue(int arrayMaxSize) {
maxSize = arrayMaxSize;
rear = -1; // 尾指针,指向队列最后一个元素
front = -1; // 头指针,指向队列第一个元素的前一个位置
arr = new int[maxSize];
}
public boolean isFull() {
return rear == maxSize - 1;
}
public boolean isEmpty() {
return rear == front;
}
// 队列添加元素
public void add(int value) {
if (isFull()) {
System.out.println("队列满,无法添加");
return;
}
rear++;
arr[rear] = value;
}
// 队列取数据
public int get() {
if (isEmpty()) {
throw new RuntimeException("队列为空");
}
front++;
return arr[front];
}
// 展示队列所有数据
public void showQueue() {
if (isEmpty()) {
System.out.println("队列为空,没有数据");
return;
}
for (int i = 0; i < arr.length; i++) {
System.out.printf("arr[%d]=%d\n", i, arr[i]);
}
}
// 展示队列头数据
public int showHead() {
if (isEmpty()) {
throw new RuntimeException("队列为空");
}
return arr[front + 1];
}
}
\