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

你可能感兴趣的文章
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>