博客
关于我
数组模拟队列
阅读量: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/

你可能感兴趣的文章
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
mysql client library_MySQL数据库之zabbix3.x安装出现“configure: error: Not found mysqlclient library”的解决办法...
查看>>
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>