美文网首页程序员
数组实现环形队列

数组实现环形队列

作者: YAOPRINCESS | 来源:发表于2020-06-30 23:56 被阅读0次
image.png
看我画的图!
我这里实现的是循环队列

front:指向第一个数据的位置
rear:指向最后一个数据的下一个位置
maxSize:数组的长度
重点:rear指向的地方永远为空,不存数据,我们这里牺牲了数组的一个单位来实现对队列为满条件的判断,你可以认为这个数组能存的最大数据个数永远为maxSize-1(数组长度减一)


front和rear的初始值都为0
判断队列为空:front==rear
判断队列为满:rear=(rear+1)%maxSize
计算队列元素个数:(rear-front+maxSize)%maxSize


它的简易版为单向队列,请点击传送门


以下为代码实现,演示请使用如下命令:
javac -encoding utf-8 CircleQueue.java
java CircleQueue


import java.util.Scanner;
public class CircleQueue{

    private int front;//指向第一个数据的位置
    private int rear;//指向最后一个数据的下一个位置
    private int maxSize;//数组大小
    private int[] arr;
    public static void main(String[] args) {
        
        CircleQueue cq = new CircleQueue(4);
        char key=' ';//接收用户输入的第一个字符
        Scanner scanner =new Scanner(System.in);//读取用户输入

        boolean flag = true;
        while(flag){
            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':
                    cq.showQueue();
                    break;
                case 'e':
                    scanner.close();
                    flag=false;
                    break;
                case 'a':
                    System.out.println("请输入要添加的数据");
                    int data=scanner.nextInt();
                    cq.addQueue(data);
                    break;
                case 'g':
                    try {
                        int result= cq.getQueue();
                        System.out.printf("取出的数据是%d\n",result);
                    } catch (Exception e) {
                        System.out.println(e.getMessage());
                    }
                    break;
                case 'h':
                    try {
                        int result= cq.headQueue();
                        System.out.printf("队列头数据是%d\n",result);
                    } catch (Exception e) {
                        System.out.println(e.getMessage());
                    }
                    break;
                default:
                    break;                    
            }

        }
        System.out.println("程序退出");
        
    }

    public CircleQueue(int size){
        front=0;
        rear=0;
        maxSize=size;
        arr=new int[maxSize];
    }

    //判断是否为空
    public boolean isEmpty(){
        return front==rear;
    }

    //判断是否已满
    public boolean isFull(){
        return (rear+1)%maxSize==front;
    }

    //增加一个元素
    public void addQueue(int param){
        if(isFull()){
            System.out.println("队列已满,无法添加");
            return;
        }
        arr[rear]=param;
        rear=(rear+1)%maxSize;//避免超过数组大小
    }

    //弹出队首元素
    public int getQueue(){
        if(isEmpty()){
            throw new RuntimeException("队列为空,队首无元素可弹出");
        }
        int value=arr[front];
        front=(front+1)%maxSize;//避免超过数组大小
        return value;
    }
    
    //查看队首元素
    public int headQueue(){
        if(isEmpty()){
            throw new RuntimeException("队列为空,队首无元素可查看");
        }
        return arr[front];
    }

    //展示队列元素
    public void showQueue(){
        if(isEmpty()){
            System.out.println("队列为空");
        }
        for(int i=front;i<(front+size());i++){
            System.out.printf("arr[%d]=%d\n",i%maxSize,arr[i%maxSize]);
        }
    }

    //计算队列当前元素个数
    public int size(){
        return (rear-front+maxSize)%maxSize;
    }
}

相关文章

  • 数据结构

    稀疏数组 代码实现: 队列 代码实现: 环形队列 什么时候队列满:(rear+1)%maxsize == fron...

  • 数组实现环形队列

    利用数组结构在队列的基础下用取模算法来实现环形队列。 环形队列拥有复用功能。 主要算法思想:1)front指向队列...

  • 数据结构之队列

    什么是队列 队列是一个有序列表, 可以用数组或链表实现 先入先出 使用数组模拟队列和环形队列 用数组模拟队列 思路...

  • workQueue有以下七种选择

    : ArrayBlockingQueue:一个由数组结构组成的有界阻塞队列(数组结构可配合指针实现一个环形队列)。...

  • 数组实现环形队列

    我这里实现的是循环队列 front:指向第一个数据的位置rear:指向最后一个数据的下一个位置maxSize:数组...

  • 使用数组实现环形队列

    整体思路解析 上次我们演示了使用数组实现队列的方式,在结尾处提出了一个问题,因为我们使用双指针后移的方式,被弹出队...

  • 数组实现的环形队列

    基本思想: 环形展开成链表,在链表上模拟环形队列; head 和tail只增不减,add 、remove、size...

  • 环形队列-数组简单实现

  • 循环队列

    顺序存储实现循环队列 使用数组模拟环形结构,数组大小为MAXQSIZE front表示队头元素 rear表示队尾元...

  • 队列和栈的底层实现、环形数组、最小栈、栈相关

    01实现一个可以在两端进出的栈、队列 环形数组 最小栈GetMinStack 两个栈实现一个队列 TwoStack...

网友评论

    本文标题:数组实现环形队列

    本文链接:https://www.haomeiwen.com/subject/ydfqqktx.html