循环队列、双端队列

news2025/1/16 5:50:20

循环队列、双端队列

  • 1. 循环队列
  • 1.1 循环队列
  • 1.2 代码实现
  • 1.3 力扣622. 设计循环队列
  • 2. 双端队列

1. 循环队列

1.1 循环队列

在这里插入图片描述

  • 特殊的队列,首尾相连,空间可重复利用
  • 环形队列常使用数组实现,且为了方便队列的判空、判满处理,会浪费一个大小的空间,该空间不存储元素,比如待存储元素共n个,则开辟大小为n+1的数组实现循环队列
  • 循环队列,判空:head=tail;判满:(tail+1)%arr.length=head
  • head、tail分别为头指针、尾指针,初始化时均指向index=0位置;
  • head指向队头元素,tail指向队尾元素的下一个位置
  • 元素出队时,front_val=arr[head]
  • 元素入队时,arr[tail]=val、tail=(tail+1)%n
  • 队尾元素位置为:lastIndex=(tail-1+n)%n
  • 队列中有效元素下标为:[head,lastIndex]

初始化,队列为空:
在这里插入图片描述

队列满:
在这里插入图片描述

  • 涉及到下标移动,有两个计算公式,其中offset=offset%arr.length
    1)下标最后再往后(offset 小于 array.length): index = (index + offset) % arr.length
    2)下标最前再往前(offset 小于 array.length): index = (index + arr.length - offset) % arr.length

1.2 代码实现

public class LoopQueue{
    // 队列:存储数据
    private int[] data;
    // 队列实际长度,其中1个位置不存储数据
    private int n;
    // 头指针、尾指针
    private int head,tail;

    public LoopQueue(int size){
        data=new int[size+1];
        n=data.length;
        head=0;
        tail=0;
    }
    public boolean isEmpty() {
        return head==tail;
    }

    public boolean isFull() {
        return (tail+1)%n==head;
    }
    // 入队操作
    public boolean offer(int val) {
        if (isFull()){
            return false;
        }
        data[tail]=val;
        tail=(tail+1)%n;
        return true;
    }

    // 出队操作
    public int poll() {
        if (isEmpty()){
            throw new NoSuchElementException("队列为空,无法进行出队操作!");
        }
        int val=data[head];
        head=(head+1)%n;
        return val;
    }

    // 获取队头元素
    public int peek() {
        if (isEmpty()){
            throw new NoSuchElementException("队列为空,无法获取队头元素!");
        }
        return data[head];
    }

    // 遍历队列
    @Override
    public String toString() {
        StringBuilder content=new StringBuilder("[");
        int i=head;
        while (i!=tail){
            content.append(data[i]);
            if (i!=tail-1){
                content.append(",");
            }
            i=(i+1)%n;
        }
        content.append("]");
        return content.toString();
    }
}

1.3 力扣622. 设计循环队列

622. 设计循环队列
设计你的循环队列实现。 循环队列是一种线性数据结构,其操作表现基于 FIFO(先进先出)原则并且队尾被连接在队首之后以形成一个循环。它也被称为“环形缓冲器”。
循环队列的一个好处是我们可以利用这个队列之前用过的空间。在一个普通队列里,一旦一个队列满了,我们就不能插入下一个元素,即使在队列前面仍有空间。但是使用循环队列,我们能使用这些空间去存储新的值。
你的实现应该支持如下操作:
MyCircularQueue(k): 构造器,设置队列长度为 k 。
Front: 从队首获取元素。如果队列为空,返回 -1 。
Rear: 获取队尾元素。如果队列为空,返回 -1 。
enQueue(value): 向循环队列插入一个元素。如果成功插入则返回真。
deQueue(): 从循环队列中删除一个元素。如果成功删除则返回真。
isEmpty(): 检查循环队列是否为空。
isFull(): 检查循环队列是否已满。

class MyCircularQueue {
    int[] queue;
    int head;
    int tail;
    int n;
    public MyCircularQueue(int k) {
        queue=new int[k+1];
        head=0;
        tail=0;
        n=queue.length;
    }

    public boolean enQueue(int value) {
        if (isFull()){
            return false;
        }
        queue[tail]=value;
        tail=(tail+(1%n))%n;
        return true;
    }

    public boolean deQueue() {
        if (isEmpty()){
            return false;
        }
        head=(head+1)%n;
        return true;
    }

    public int Front() {
        if (isEmpty()){
            return -1;
        }
        int val=queue[head];
        return val;
    }

    public int Rear() {
        if (isEmpty()){
            return -1;
        }
        int val=queue[(tail-1+n)%n];
        return val;
    }

    public boolean isEmpty() {
        return head==tail;
    }

    public boolean isFull() {
        return (tail+1)%n==head;
    }
}

2. 双端队列

  • 双端队列deque 是 “double ended queue” 的简称,是指允许两端都可以进行入队和出队操作的队列;
    在这里插入图片描述
  • Java中使用Deque接口表示双端队列,其实现类有LinkedList、ArrayDeque两个;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/494477.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

二十七、BGP技术总结

文章目录 BGP:边界网关路由协议(Border Gateway Protocol)概述1、路由协议分类1.1、IGP:Interior Gateway Protocol(内部网关协议)1.2、EGP:Exterior Gateway Protocol(外部网关协议…

人机智能中几个困难问题浅析

1、人机之间与人人之间信任的区别人机之间的信任与人人之间的信任存在以下异同:①信任对象。人机之间的信任的对象是计算机系统、算法、机器人等,而人人之间的信任的对象是其他人。②信任方式。人机之间的信任是基于技术、安全协议等建立的,例…

Baumer工业相机堡盟工业相机如何联合BGAPISDK和Halcon实现图像的线性灰度变换Emphasize 算法增强(C#)

Baumer工业相机堡盟工业相机如何联合BGAPISDK和Halcon实现图像的线性灰度变换算法增强(C#) Baumer工业相机Baumer工业相机使用图像算法增加图像的技术背景Baumer工业相机通过BGAPI SDK联合Halcon使用Emphasize 线性灰度变换增强算法1.引用合适的类文件2.…

基于标签的协同过滤算法实现与个人兴趣相关的文章推荐

一、前言 在当前信息爆炸的时代,每天都会涌现出大量的文章,人们有时候会感到信息的获取难度比筛选更大。而作为信息的提供者,我们应当为用户提供依据个人兴趣的文章推荐。 本项目中的文章标签相似度推荐功能使用了一种基于标签的协同过滤算…

【设计模式】抽象工厂模式

【设计模式】抽象工厂模式 参考资料: Java设计模式 - 抽象工厂模式 重学 Java 设计模式:实战抽象工厂模式 文章目录 【设计模式】抽象工厂模式一、抽象工厂模式介绍1.1、什么是工厂方法模式1.2、角色概述 二、案例场景模拟2.1、背景一:Redis…

Camtasia2023最好用的电脑屏幕录制软件

Camtasia2023是市场上最好的录像机和屏幕录制软件之一。强大的软件视频编辑程序的Camtasia 适用于Windows和iOS。 它支持多种流行的媒体格式,并对您创建的视频提供令人印象深刻的控制范围。3000多万专业人士在全球范围内使用Camtasia展示产品,教授课程&a…

.netCHARTING 10.5 dotnetcharting Crack

.net图表 10.5 为柱形图和条形图添加拐角半径控件。 5月 05, 2023 - 16:18新版本 特征 直角或直线组织连接线 - 默认情况下,通过以直角绘制组织连接线来增强组织连接线的显示方式。您可以使用直线选项更改此默认值,并直接在点…

mssql修改排序规则

修改排序规则 在 Microsoft SQL Server 中,可以通过以下步骤来修改排序规则: 打开 SQL Server Management Studio(SSMS),连接到 SQL Server 数据库实例。在“对象资源管理器”窗格中,右键单击数据库&…

VS+Qt+C++医院排队叫号系统

程序示例精选 VSQtC医院排队叫号系统 如需安装运行环境或远程调试&#xff0c;见文章底部个人QQ名片&#xff0c;由专业技术人员远程协助&#xff01; 前言 这篇博客针对<<VSQtC医院排队叫号系统>>编写代码&#xff0c;带用户登录&#xff0c;管理员登录&#xff…

开源进展 | WeIdentity v3.1.0 发布,新增数据库部署和使用模式

作为连接实体对象&#xff08;人或物&#xff09;的现实身份与链上身份的可信映射&#xff0c;实现实体对象之间安全可信的数据授权与交换&#xff0c;分布式身份技术解决方案在推动区块链应用繁荣及可信数据流转的过程中扮演着重要角色。 WeIdentity是由微众银行自主研发并完全…

荟萃金融科技成果,展现数字金融力量丨通付盾受邀出席中国国际金融展

2023年4月27日&#xff0c;中国国际金融展在北京顺利落下帷幕。本届金融展以“荟萃金融科技成果&#xff0c;展现数字金融力量&#xff0c;谱写金融服务中国式现代化新篇章”为主题&#xff0c;由中国金融电子化集团有限公司和北京市石景山区政府联合主办。来自国内外的众多金融…

教室资源管理系统【纯控制台】(Java课设)

系统类型 纯控制台类型&#xff08;没有用到数据库&#xff09; 使用范围 适合作为Java课设&#xff01;&#xff01;&#xff01; 部署环境 jdk1.8Idea或eclipse 运行效果 本系统源码地址&#xff1a;https://download.csdn.net/download/qq_50954361/87753360 更多系统…

helm部署nacos

1.去helm仓库拉取nacos包 https://artifacthub.io/packages/helm/kubegemsapp/nacos?modalinstall helm repo add kubegemsapp https://charts.kubegems.io/kubegemsapp helm pull kubegemsapp/nacos tar -zxvf nacos-0.1.5.tgz mkdir -p nacos/ci/test2.修改chart配置文件 …

如何根据期刊缩写查找期刊?

英文论文写作中&#xff0c;经常会插入参考文献。参考文献中的期刊名称&#xff0c;时常需要使用缩写。或者是手头有期刊缩写后的名称&#xff0c;但是有时候&#xff0c;查了半天也查不到期刊期刊全称&#xff0c;费时费力让人崩溃。今天就给各位学者老师总结一些查询期刊缩写…

如何在 Python 开发环境中调用 ChatGPT 模型?

本文将演示在本地的 python 项目中调用 ChatGPT 模型。 写在前面第一步&#xff1a;获取 API Key第二步&#xff1a;安装 OpenAI 第三方库第三步&#xff1a;Python 开发环境中调用 ChatGPT 模型 写在前面 作为一名程序员&#xff0c;在开发过程当中时常需要使用 ChatGPT 来完…

项目创建第一天 搭建前端环境

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、环境是什么&#xff1f;二、使用步骤1.前台搭建方式1.创建项目2.目录结构3. 安装elementui4. 创建路由5.使用axios6.bug记录6.1出现跨域问题6.2 解决方式6.…

硬盘数据突然消失怎么回事?硬盘数据突然消失怎么找回

硬盘上的数据对每个人都至关重要&#xff0c;它可能是我们的珍贵回忆&#xff0c;多年学习的总结&#xff0c;或者一些不可告人的秘密。而硬盘中的数据可能会在不知情的情况下消失或被删除&#xff0c;这种情况对我们来说十分痛苦和困扰。然而&#xff0c;我们不必担心&#xf…

SLAM论文速递:SLAM—(2021)Amos-SLAM:一种基于视觉和几何的抗动态双阶段SLAM方法—5.65(1)

论文信息 题目&#xff1a; Visual SLAM in dynamic environments based on object detection 基于目标检测的动态环境下的视觉SLAM论文地址&#xff1a; https://www.sciencedirect.com/science/article/pii/S2214914720304402发表期刊&#xff1a; Defence Technology,&…

【python】pytorch包:深度学习(序章)

今日听闻师姐说pytorch实现深度学习要比keras更好用一些&#xff0c;特此记录 Part 0. 机器学习 与 深度学习 的联系与区别 参考B站视频链接 联系 深度学习是机器学习的分支&#xff0c;人工神经网络为基础&#xff0c;对数据的特征进行学习的方法 区别 特征抽取 机器学…

TensorRT入门实战,TensorRT Plugin介绍以及TensorRT INT8加速

文章目录 一、TensorRT介绍,工作流程和优化策略TensorRT是什么TensorRT的工作流程TRT优化策略介绍 二、TensorRT的组成和基本使用流程三、TensorRT的基本使用流程四、TensorRT Demo代码 : SampleMNISTCaffe Parser方式构建 五. TensorRT Plugin基本概念工作流程API介绍Dynamic …