博客
关于我
数组模拟队列
阅读量:515 次
发布时间:2019-03-07

本文共 5584 字,大约阅读时间需要 18 分钟。

组模拟队

出队列操作getQueue

显示队列的情况showQueue

查看队列头元素headQueue

退出系统exit

 

ArrayQueueDemo.java

package com.dym.queue;import java.util.Scanner;public class ArrayQueueDemo {    public static void main(String[] args) {        //测试一把        //创建一个队列        ArrayQueue queue = new ArrayQueue(3);        char key = ' '; //接收用户输入        Scanner scanner = 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 = scanner.next().charAt(0);//接收一个字符            switch (key) {                case 's':                    queue.showQueue();                    break;                case 'a':                    System.out.println("输出一个数");                    int value = scanner.nextInt();                    queue.addQueue(value);                    break;                case 'g': //取出数据                    try {                        int res = queue.getQueue();                        System.out.printf("取出的数据是%d\n", res);                    } catch (Exception e) {                        // TODO: handle exception                        System.out.println(e.getMessage());                    }                    break;                case 'h': //查看队列头的数据                    try {                        int res = queue.headQueue();                        System.out.printf("队列头的数据是%d\n", res);                    } catch (Exception e) {                        // TODO: handle exception                        System.out.println(e.getMessage());                    }                    break;                case 'e': //退出                    scanner.close();                    loop = false;                    break;                default:                    break;            }        }        System.out.println("程序退出~~");    }}// 使用数组模拟队列-编写一个ArrayQueue类class ArrayQueue {    private int maxSize; // 表示数组的最大容量    private int[] arr; // 该数据用于存放数据, 模拟队列    private int front; // 队列头    private int rear; // 队列尾    // 创建队列的构造器    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++; // 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()) {            throw new RuntimeException("队列空的,没有数据~~");        }        return arr[front + 1];    }}

D:\soft\Java\jdk1.8.0_261\bin\java.exe "-javaagent:D:\soft\IntelliJ IDEA 2019.3.5\lib\idea_rt.jar=51051:D:\soft\IntelliJ IDEA 2019.3.5\bin" -Dfile.encoding=UTF-8 -classpath D:\soft\Java\jdk1.8.0_261\jre\lib\charsets.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\deploy.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\access-bridge-64.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\cldrdata.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\dnsns.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\jaccess.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\jfxrt.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\localedata.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\nashorn.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\sunec.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\sunjce_provider.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\sunmscapi.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\sunpkcs11.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\ext\zipfs.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\javaws.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\jce.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\jfr.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\jfxswt.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\jsse.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\management-agent.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\plugin.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\resources.jar;D:\soft\Java\jdk1.8.0_261\jre\lib\rt.jar;D:\IDEAWorkSpace\dym_DataStructures\out\production\dym_DataStructures com.dym.queue.ArrayQueueDemo

s(show): 显示队列
e(exit): 退出程序
a(add): 添加数据到队列
g(get): 从队列取出数据
h(head): 查看队列头的数据
s
队列空的,没有数据~~
s(show): 显示队列
e(exit): 退出程序
a(add): 添加数据到队列
g(get): 从队列取出数据
h(head): 查看队列头的数据
a
输出一个数
1
s(show): 显示队列
e(exit): 退出程序
a(add): 添加数据到队列
g(get): 从队列取出数据
h(head): 查看队列头的数据
a
输出一个数
2
s(show): 显示队列
e(exit): 退出程序
a(add): 添加数据到队列
g(get): 从队列取出数据
h(head): 查看队列头的数据
a
输出一个数
3
s(show): 显示队列
e(exit): 退出程序
a(add): 添加数据到队列
g(get): 从队列取出数据
h(head): 查看队列头的数据
s
arr[0]=1
arr[1]=2
arr[2]=3
s(show): 显示队列
e(exit): 退出程序
a(add): 添加数据到队列
g(get): 从队列取出数据
h(head): 查看队列头的数据
h
队列头的数据是1
s(show): 显示队列
e(exit): 退出程序
a(add): 添加数据到队列
g(get): 从队列取出数据
h(head): 查看队列头的数据
g
取出的数据是1
s(show): 显示队列
e(exit): 退出程序
a(add): 添加数据到队列
g(get): 从队列取出数据
h(head): 查看队列头的数据

转载地址:http://qtznz.baihongyu.com/

你可能感兴趣的文章
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>