专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

队列进化->环形队列

前言

队列(Queue)是一个很常见的数据结构类型,今天学习了一个队列的升级版——环形队列,在这里总记录一下~( ̄▽ ̄)~*。

性质

1、 约定front指向队列的第一个元素,也就是说data[front]就是队头数据,front初始值为0。
2、 约定rear指向队列的最后一个元素的后一个,也就是说data[rear-1]就是队尾数据,rear初始值为0。 如下图

54_1.png

##

1、 队列满的条件是:( rear+1 )% maxSize == front
2、 队列空的条件是:rear == front
3、 队列中的元素个数为:( rear + maxsize – front) % maxSize因为rear指向队尾的后面一个位置,这个位置就不能存数据,因此有效数据只有maxSize-1个

实现(java版)

class CircleArray {

    private int maxSize;//表示数组的最大容量
    private int front;//队列头:指向队列的第一个元素
    private int rear;//队列的最后一个元素的后一个位置
    private int[] arr;//用于存放数据,模拟对列

    public CircleArray(int arrMaxSize){
        maxSize = arrMaxSize;
        arr = new int[maxSize];
    }
    //判断队列是否满
    public boolean isFull(){
        return (rear+1) % maxSize == front;
    }
    //判断队列是否为空
    public boolean isEmpty(){
        return rear == front;
    }

    //添加数据到队列
    public void addQueue(int n){
        //判断队列是否满
        if(isFull()){
            System.out.println("队列满,不能添加数据");
            return;
        }
        //直接将数据加入
        arr[rear] = n;
        //将rear后移,考虑取模
        rear = (rear +1 ) % maxSize;
    }

    //获取队列的数据,出队列
    public int getQueue(){
        //判断队列是否空
        if (isEmpty()){
            //通过抛出异常
            throw new RuntimeException("队列空,不能取数据");
        }
        //front是指向队列的第一个元素.1.先把front对应的值保留到一个临时变量
        //2.将front后移,考虑取模
        //3.将临时保存的变量返回
       int value =  arr[front];
        front= (front+1)%maxSize;
        return value;
    }

    //显示队列的所有数据
    public void showQueue(){
        //遍历
        if (isEmpty()){
            System.out.println("队列是空的,没有数据");
            return;
        }
        //思路:从front开始遍历,遍历多少个元素
        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 + maxSize - front) % maxSize;
    }
    //显示队列的头部,不是取出数据
    public int headQueue(){
        //判断
        if(isEmpty()){
            throw new RuntimeException("队列空,不能取数据");
        }
        return  arr[front];
    }

}

希望对你有帮助 (*^-^*)

文章永久链接:https://tech.souyunku.com/29478

未经允许不得转载:搜云库技术团队 » 队列进化->环形队列

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们