广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java数据结构与算法之循环队列的实现
  • 783
分享到

Java数据结构与算法之循环队列的实现

2024-04-02 19:04:59 783人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录概述循环队列循环队列实现改变队列大小enqueue 方法dequeue 方法main完整代码 概述 从今天开始, 小白我将带大家开启 Jave 数据结构 & 算法的新篇章

概述

从今天开始, 小白我将带大家开启 Jave 数据结构 & 算法的新篇章.

循环队列

循环队列 (Circular Queue) 是一种特殊的队列. 循环队列解决了队列出队时需要将所有数据前移一位 (复杂度为 O(n)) 的问题.

循环队列的底层依然是数组, 不过增加了指向头和尾的指针.

循环队列实现

  1. 判断队列是否为空: 当头指针 Q.front == 尾指针 Q.rear, 队列为空
  2. 判断队列是否为满: 当头指针 Q.front == 尾指针 Q.rear + 1) % Maxsize, 队列为满

改变队列大小


// 改变队列大小
private void resize(int capacity) {
	// 定义新数组
    E[] newData = (E[]) new Object[capacity + 1];
    
    // 转移数组元素
    for (int i = 0; i < size; i++) {
        newData[i] = data[(i +front) % data.length];
    }

    // 更新
    data = newData;
    front = 0;
    rear = size;
}

enqueue 方法


// 入队
public void enqueue(E e) {

    // 判断是否为满
    if((rear + 1) % data.length == front) {
        resize(getCapacity() * 2);
    }

    // 队伍加入
    data[rear] = e;
    rear = (rear + 1) % data.length;
    size++;
}

dequeue 方法


// 出队
public E dequeue() {

    // 判断是否为空
    if(isEmpty()) {
        throw new RuntimeException("队列为空");
    }

    // 取出第一个元素
    E element = data[front];
    data[front] = null;

    // 移动头指针
    front = (front + 1) % data.length;

    // 数组大小-1
    size--;

    // 判断是否需要缩小
    if(size==getCapacity() / 4 && getCapacity() / 2 != 0) {
        resize(getCapacity() / 2);
    }

    return element;
}

main


// 主函数
public static void main(String[] args) {

    // 创建循环队列
    CircularQueue<Integer> queue = new CircularQueue<>(5);

    // 入队
    for (int i = 0; i < 8; i++) {
        queue.enqueue(i);
        System.out.println(queue);
    }

    // 出队
    for (int i = 0; i < 8; i++) {
        queue.dequeue();
        System.out.println(queue);
    }
}

输出结果:

CircularQueue{data=[0, null, null, null, null, null], front=0, rear=1, size=1}

CircularQueue{data=[0, 1, null, null, null, null], front=0, rear=2, size=2}

CircularQueue{data=[0, 1, 2, null, null, null], front=0, rear=3, size=3}

CircularQueue{data=[0, 1, 2, 3, null, null], front=0, rear=4, size=4}

CircularQueue{data=[0, 1, 2, 3, 4, null], front=0, rear=5, size=5}

CircularQueue{data=[0, 1, 2, 3, 4, 5, null, null, null, null, null], front=0, rear=6, size=6}

CircularQueue{data=[0, 1, 2, 3, 4, 5, 6, null, null, null, null], front=0, rear=7, size=7}

CircularQueue{data=[0, 1, 2, 3, 4, 5, 6, 7, null, null, null], front=0, rear=8, size=8}

CircularQueue{data=[null, 1, 2, 3, 4, 5, 6, 7, null, null, null], front=1, rear=8, size=7}

CircularQueue{data=[null, null, 2, 3, 4, 5, 6, 7, null, null, null], front=2, rear=8, size=6}

CircularQueue{data=[null, null, null, 3, 4, 5, 6, 7, null, null, null], front=3, rear=8, size=5}

CircularQueue{data=[null, null, null, null, 4, 5, 6, 7, null, null, null], front=4, rear=8, size=4}

CircularQueue{data=[null, null, null, null, null, 5, 6, 7, null, null, null], front=5, rear=8, size=3}

CircularQueue{data=[6, 7, null, null, null, null], front=0, rear=2, size=2}

CircularQueue{data=[7, null, null], front=0, rear=1, size=1}

CircularQueue{data=[null, null], front=0, rear=0, size=0}

完整代码 


import java.util.ArrayList;
import java.util.Arrays;

public class CircularQueue<E> {

    private E[] data;
    private int front, rear;
    private int size;

    // 无参构造
    public CircularQueue() {
        this(10);
    }

    // 有参构造
    public CircularQueue(int capacity) {
       data = (E[]) new Object[capacity + 1];
       front = rear = size = 0;
    }

    // 入队
    public void enqueue(E e) {

        // 判断是否为满
        if((rear + 1) % data.length == front) {
            resize(getCapacity() * 2);
        }

        // 队伍加入
        data[rear] = e;
        rear = (rear + 1) % data.length;
        size++;
    }

    // 出队
    public E dequeue() {

        // 判断是否为空
        if(isEmpty()) {
            throw new RuntimeException("队列为空");
        }

        // 取出第一个元素
        E element = data[front];
        data[front] = null;

        // 移动头指针
        front = (front + 1) % data.length;

        // 数组大小-1
        size--;

        // 判断是否需要缩小
        if(size==getCapacity() / 4 && getCapacity() / 2 != 0) {
            resize(getCapacity() / 2);
        }

        return element;
    }

    // 获取队列大小
    public int getSize() {
        return size;
    }

    // 获取队列容量
    public int getCapacity() {
        return data.length - 1;
    }

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

    // 改变队列大小
    private void resize(int capacity) {

        // 创建新数组
        E[] newData = (E[]) new Object[capacity + 1];

        // 转移数组元素
        for (int i = 0; i < size; i++) {
            newData[i] = data[(i +front) % data.length];
        }

        // 更新
        data = newData;
        front = 0;
        rear = size;
    }

    @Override
    public String toString() {
        return "CircularQueue{" +
                "data=" + Arrays.toString(data) +
                ", front=" + front +
                ", rear=" + rear +
                ", size=" + size +
                '}';
    }

    // 主函数
    public static void main(String[] args) {

        // 创建循环队列
        CircularQueue<Integer> queue = new CircularQueue<>(5);

        // 入队
        for (int i = 0; i < 8; i++) {
            queue.enqueue(i);
            System.out.println(queue);
        }

        // 出队
        for (int i = 0; i < 8; i++) {
            queue.dequeue();
            System.out.println(queue);
        }
    }
} 

到此这篇关于Java数据结构与算法之循环队列的实现的文章就介绍到这了,更多相关Java数据结构 循环队列内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java数据结构与算法之循环队列的实现

本文链接: https://www.lsjlt.com/news/159856.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java数据结构与算法之循环队列的实现
    目录概述循环队列循环队列实现改变队列大小enqueue 方法dequeue 方法main完整代码 概述 从今天开始, 小白我将带大家开启 Jave 数据结构 & 算法的新篇章...
    99+
    2022-11-12
  • 数据结构之——Python实现循环队列
    栈是先入后出,与之相反的是队列,队列是先进先出的线性结构。队列是只允许在一端进行插入操作,而在另一端进行删除操作的线性表。允许插入的一端称为队尾,允许删除的一端称为队头。 图1 队列的定义 队列的存储结构中使用的最多的是循...
    99+
    2023-01-31
    数据结构 队列 Python
  • Java 数据结构与算法系列精讲之队列
    目录概述队列队列实现enqueue 方法dequeue 方法main完整代码概述 从今天开始, 小白我将带大家开启 Jave 数据结构 & 算法的新篇章. 队列 队列 (Q...
    99+
    2022-11-13
  • JavaScript数据结构之优先队列与循环队列的示例分析
    这篇文章将为大家详细讲解有关JavaScript数据结构之优先队列与循环队列的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:优先队列实现一个优先队列:设...
    99+
    2022-10-19
  • C语言数据结构算法基础之循环队列示例
    目录说明示例代码1. 首先定义结构体:2. 定义各种算法:3. 测试:4. 最后的结果:说明 循环队列是一种先进先出的,首尾相连的队列。 大致的结构如下图: 用数组来抽象的表示一下...
    99+
    2022-11-13
  • java数据结构基础:顺序队列和循环队列
    目录队列:顺序队列:代码实现:循环队列:代码实现:总结队列: 队列是一种受限制的线性表 只允许在表的一端进行插入,另一端进行删除 插入的一端称作队尾,删除的一端称作队头 具有先进先出...
    99+
    2022-11-12
  • java 数据结构之栈与队列
    java 数据结构之栈与队列一:对列队列是一种先进先出的数据结构实现代码:package Queue; public class Queue { //队列类 private int maxSize; //定义队列的长度 ...
    99+
    2023-05-31
    java 队列
  • Java数据结构与算法学习之循环链表
    目录存储结构示意图初始化循环链表 循环链表的插入首位置代码实现其他位置代码实现(总)循环链表的删除1.操作的为第一个元素2.操作元素不为第一个元素代码实现(总)循环链表的常见操作  ...
    99+
    2022-11-12
  • C语言数据结构与算法之队列的实现详解
    目录队列的概念及结构队列的实现Queue.hQueue.cTest.c队列的概念及结构 队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出FI...
    99+
    2022-11-13
    C语言数据结构 队列 C语言 队列实现 C语言 队列
  • Java数据结构与算法之稀疏数组与队列深入理解
    目录一、数据结构和算法简介二、稀疏数组稀疏数组的应用实例二维数组与稀疏数组的转换二维数组 转 稀疏数组的思路稀疏数组 转 原始的二维数组的思路三、队列数组模拟队列代码优化:数组模拟环...
    99+
    2022-11-12
  • java数据结构循环队列的空满判断及长度计算
    目录一、假溢出二、循环队列判断是空是满三、循环队列的长度计算四、代码实现在上一章中,使用了数组模拟了队列。但是留下的问题是,把数据取完后,再往里加数据就不行了。 一、假溢出 这是因为...
    99+
    2022-11-13
  • Java数据结构之栈与队列实例详解
    目录一,栈1,概念2,栈的操作3,栈的实现 4,实现mystack二,队列1,概念 2,队列的实现 3,实现myqueue栈、队列与数组的区别?总结 一,栈 1,概念 在我们软件应用...
    99+
    2022-11-12
  • 带你了解Java数据结构和算法之队列
    目录1、队列的基本概念2、Java模拟单向队列实现3、双端队列4、优先级队列5、总结1、队列的基本概念 队列(queue)是一种特殊的线性表,特殊之处在于它只允许在表的前端(fron...
    99+
    2022-11-13
  • JS数据结构与算法中的队列结构详解
    目录队列结构一.认识队列二.队列的应用三.队列类的创建四.队列的常见操作五.击鼓传花六.优先级队列七.优先级队列的实现队列结构 一.认识队列 受限的线性结构:我们已经学习了一种受限的...
    99+
    2022-11-13
    JS数据结构与算法 JS队列结构
  • Java队列数据结构的实现
    1.队列的基本概念 什么是队列 队列是一种特殊的线性表它只允许在表的前端(队头)进行删除操作在表的后端(队尾)进行插入操作队列是一个有序表(可以用数组或链表实现)队列先进先出队列开辟...
    99+
    2022-11-12
  • Python 数据结构之队列的实现
    Python 队列 Queue 队列是一种先进先出(FIFO)的数据类型, 新的元素通过 入队 的方式添加进 Queue 的末尾, 出队 就是从 Queue 的头部删除元素. 用列表来做 Queue: ...
    99+
    2022-06-04
    数据结构 队列 Python
  • Java数据结构与算法系列精讲之哈希算法实现
    概述 从今天开始, 小白我将带大家开启 Java 数据结构 & 算法的新篇章. 获取哈希值 hashCode()方法可以返回一个对象的哈希值. 需要注意的是, 我们需要对值...
    99+
    2022-11-13
  • Java数据结构与算法系列精讲之环形链表
    目录概述链表环形链表环形链表实现Node 类insert 方法remove 方法main完整代码概述 从今天开始, 小白我将带大家开启 Java 数据结构 & 算法的新篇章....
    99+
    2022-11-13
  • Java数据结构之堆(优先队列)的实现
    堆(优先队列)是一种典型的数据结构,其形状是一棵完全二叉树,一般用于求解topk问题。根据双亲节点大于等于孩子节点或双亲节点小于等于孩子节点,可分为大顶堆和小顶堆,本文实现大顶堆。 ...
    99+
    2022-11-13
  • java数据结构中顺序队列和循环队列的区别是什么
    这篇文章主要介绍“java数据结构中顺序队列和循环队列的区别是什么”,在日常操作中,相信很多人在java数据结构中顺序队列和循环队列的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java数据结构中...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作