美文网首页
环形队列

环形队列

作者: 桑鱼nicoo | 来源:发表于2020-02-19 09:42 被阅读0次

利用数组通过取模的方式实现环形队列,使队列达到复用的效果。


图一

图1中,rear和front分别代表队尾和队头并且初始化值都为0,此时都指队头,开始添加队列的操作,每次添加数据后,front不变,rear后移,rear的后移单位按照公式 (rear+1)%maxSize,maxSize表示队列的长度。

图二

图2中第一行,Queue中获取数据,出队列,rear和front分别代表队尾和队头并且初始化值都为0,此时都指队头,开始取出队列的操作,每次取出数据后,front后移,rear不变,front后移单位按照(front+1)%maxSize,maxSize表示队列的长度。当front和rear都指向2的时候代表队列空了,第二行中,在队列空了的情况下继续添加数据,会在队列下标为2和0的位置上添加, 当rear指向下标为1的位置时,队列再一次满了,从而实现了环形队列的效果,在编写代码的时候通过取模的方式即可实现以上效果。添加数据和移除数据时的rear和front都通过取模的方式计算出。

public class CircleArrayQueueDemo {
    public static void main(String[] args) {
        CircleArray circleArray = new CircleArray(3);
        circleArray.addQueue(1);
        circleArray.addQueue(2);
        circleArray.showQueue();
        System.out.println("head " + circleArray.headQueue());
        System.out.println("size " + circleArray.size());
    }
}

class CircleArray{
    private int maxSize;
    private int front; // 指向队头,初始值是0
    private int rear; // 指向队尾,初始值是0,最大下标是maxSize - 1,所以rear+1 = maxSize
    private int[] arr;

    public CircleArray(int maxSize){
        this.maxSize = maxSize;
        arr = new int[maxSize];
    }

    /**
     * 判断队列是否满了
     */
    public Boolean isFull(){
        return (rear + 1) % maxSize == front; // front指向队头且初始值为0,当front指向队头且rear到最大下标+1与maxSize相等,此时取模是0,与front相等,表示队列满了
    }

    /**
     * 判断队列是否为空
     * @return
     */
    public Boolean isEmpty(){
        return rear == front;
    }

    /**
     * 添加数据
     */
    public void addQueue(int n){
        if(isFull()){
            System.out.println("队列满,不能加入数据");
            return;
        }
        arr[rear] = n;
        rear = (rear + 1) % maxSize;
    }

    /**
     * 获取队头的数据,出队列
     * @return
     */
    public int getQueue(){
        if (isEmpty()) {
            throw new RuntimeException("队列空,不能取数据");
        }
        int value = arr[front];
        front = (front + 1) % maxSize;
        return value;
    }

    /**
     * 显示队列的所有数据
     */
    public void showQueue(){
        if(isEmpty()){
            System.out.println("队列空了,没有数据");
            return;
        }

        for (int i = front;i<front+size();i++){
            System.out.printf("arr[%d]=%d\n",i % maxSize,arr[i % maxSize]);
        }
    }

    /**
     * 当前有效数据的个数
     * @return
     */
    public int size(){
        return (rear + maxSize - front) % maxSize;
    }

    /**
     * 返回队头
     * @return
     */
    public int headQueue(){
        if(isEmpty()){
            throw new RuntimeException("队列空了,没有数据");
        }
        return arr[front];
    }
}

相关文章

  • 数组实现环形队列

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

  • 2020-11-10-数据结构与算法-14(队列scala版)

    1.队列 非环形实现 2.队列环形版 核心思想: 用%来模拟循环(rear +1) /maxsize = firs...

  • 环形队列

    写完这篇文章想着以后尽量(应该说一定)使用现在正在使用的LPC系列的单片机写程序,其实内心感觉还是LPC做的相当完...

  • 环形队列

    1、概念 环形队列是一个最为简单的数据结构,底层用数组组成,然后逻辑上数组首尾相连。虽然他的结构极为简单,但是用处...

  • 环形队列

    利用数组通过取模的方式实现环形队列,使队列达到复用的效果。 图1中,rear和front分别代表队尾和队头并且初始...

  • C++数据结构探险——队列篇

    数据结构的原理 队列:先进先出(FIFO:first in first out) 普通队列: 环形队列: 以C++...

  • 数据结构

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

  • C环形队列

    环形队列是什么 队列是一种常用的数据结构,这种结构保证了数据是按照“先进先出”的原则进行操作的,即最先进去的元素也...

  • 数组环形队列

    规定: head 指向队列第一个元素;tail 指向队列最后一个元素的后一个位置。 几个问题 1. 为什么计算指针...

  • 环形超时队列

    有这样一个需求:如果连续30s没有请求包(例如登录,消息,keepalive包),服务端就要将这个用户的状态置为离...

网友评论

      本文标题:环形队列

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