数组模拟队列

1、队列是一个有序列表,可以用数组或链表来实现
2、遵循先入先出的原则。即先存入队列的数据,要先取出,后存入的要后取出

class ArrayQueue{
	 private int maxSize; //表示数组的最大容量
	 private int front; //队列头
	 private int rear; //队列尾
	 private int[] arr; //该数组用于存放数据,模拟队列
	 
	 //创建队列的构造器
	 public ArrayQueue(int arrMaxSize) {
		 maxSize = arrMaxSize;
		 arr = new int[maxSize];
		 front = -1; //指向队列头部,分析出front是指向队列头的前一个位置
		 rear = -1; //指向队列尾,指向队列尾的数据(即就是队列最后一个数据)
	 }
	//判断队列是否满
	 public boolean isFull() {
		 return rear == maxSize - 1;
	 }
	 
	 //判断队列是否为空
	 public boolean isEmpty() {
		 return rear == front;
	 }
	 
	 //添加数据到队列
	 public void addQueue(int n) {
		 //判断队列是否满
		 if(isFull()) {
			 System.out.println("队列满");
			 return;
		 }
		 rear++; //让rear后移
		 arr[rear] = n; 
	 }
	 
	 //获取队列的数据,数据出队列
	 public int getQueue() {
		 //判断队列是否为空
		 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 headQueue() {
		 //判断
		 if(isEmpty()) {
			 //System.out.println("队列空");
			 throw new RuntimeException("队列空");
		 }
		 return arr[front + 1];
	 }
 }

问题:不是环形队列,数组只用到了一次
测试:

public static void main(String[] args) {
		ArrayQueue q = new ArrayQueue(3);
		char key = ' '; //接收用户输入
		Scanner input = new Scanner(System.in);
		boolean loop = true;
		//输出一个菜单
		while(loop) {
			System.out.println("s(show):显示队列");
			System.out.println("e(exit):退出程序");
			System.out.println("a(add):添加数据到队列");
			System.out.println("g(get):从队列取出数据");
			System.out.println("h(head):查看队列头的数据");
			key = input.next().charAt(0);
			switch (key) {
			case 's':
				q.showQueue();
				break;
			case 'a':
				System.out.println("输出一个数");
				int value = input.nextInt();
				q.addQueue(value);
				break;
			case 'g':
				try {
					int res = q.getQueue();
					System.out.printf("取出的数据是%d\n", res);
				} catch (Exception e) {
					System.out.println(e.getMessage()); //此处打印的信息就是类里写的异常信息
				}
				break;
			case 'h': //查看队列头的数据
				try {
					 int res = q.headQueue();
					 System.out.printf("队列的头数据是%d\n",res);
				} catch (Exception e) {
					System.out.println(e.getMessage()); 
				}
				break;
			case 'e':
				input.close();
				loop = false;
				break;
			default:
				break;
			}
		}
		System.out.println("程序退出");
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值