【Java】/* 链式队列 和 循环队列 - 底层实现 */

news2025/2/26 23:17:31

一、链式队列

1. 使用双向链表实现队列,可以采用尾入,头出 也可以采用 头入、尾出 (LinkedList采用尾入、头出)

2. 下面代码实现的是尾入、头出:

package bageight;

/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: tangyuxiu
 * Date: 2024-08-22
 * Time: 16:44
 */
public class MyQueue<E> {
    /* 使用内部类实现链表的节点 */
    private class ListNode<E> {
        E val;
        ListNode<E> prev;
        ListNode<E> next;

        public ListNode(E val) {
            this.val = val;
        }
    }

    private ListNode<E> head;
    private ListNode<E> last;

    /* push尾入 */
    public void offer(E data) {
        ListNode<E> newNode = new ListNode<>(data);
        //1. 如果链表为null
        if (this.head == null) {
            this.head = this.last = newNode;
            return;
        }
        //2. 尾插
        this.last.next = newNode;
        newNode.prev = this.last;
        this.last = newNode;
    }

    /* poll头出 */
    public E poll() {
        //1. 如果链表为null
        if (this.head == null) {
            return null;
        }
        //2. 头出
        E del = this.head.val;
        if (this.head.next == null) {//链表只有一个节点
            this.head = this.last = null;
        } else {//链表有多个节点
            this.head = this.head.next;
            this.head.prev = null;
        }
        return del;
    }

    /* peek */
    public E peek() {
        //1. 如果链表为null
        if (this.head == null) {
            return null;
        }
        //2. 正常
        return this.head.val;
    }

    /* size */
    public int size() {
        int count = 0;
        ListNode<E> cur = this.head;
        while (cur != null) {
            count++;
            cur = cur.next;
        }
        return count;
    }
}

二、循环队列

622. 设计循环队列 - 力扣(LeetCode)

【难点】:

① 到底怎么判断什么时候队列为null,什么时候队列满了

② fast++,如何不越界:fast = fast % len 或 第三种做法要写成fast = (fast + 1) % len

【等待补充】使用flag的方式如何编写代码。

2.1 使用uesdSize判断空满

class MyCircularQueue {
    private int[] elem;//由于不是泛型类,且依据题意放入数组中的数据都是int类型的,
                       //因此如此定义
    private int head;//队头位置
    private int last;//待插入数据位置
    private int uesdSize;//队列有效数据个数

    public MyCircularQueue(int k) {
        this.elem = new int[k];
    }
    
    //尾插
    public boolean enQueue(int value) {
        if (this.isFull()) {
            return false;
        }

        this.elem[this.last] = value;
        this.last++;
        //使得last的下标一直维持在0~elem.length-1
        this.last = this.last % this.elem.length;
        this.uesdSize++;
        return true;
    }
    
    //头删
    public boolean deQueue() {
        if (this.isEmpty()) {
            return false;
        }

        //头删是让head的值++,而不是--🙀
        this.head++;
        this.head = this.head % this.elem.length;
        this.uesdSize--;
        return true;
    }
    
    //获取队头元素的值
    public int Front() {
        if (this.isEmpty()) {
            return -1;
        }

        return this.elem[this.head];
    }
    
    //获取队尾元素的值
    public int Rear() {
        if (this.isEmpty()) {
            return -1;
        }

        if (this.last == 0) {
            return this.elem[this.elem.length - 1];
        } 
        return this.elem[this.last - 1];
    }
    
    public boolean isEmpty() {
        return this.uesdSize == 0;
    }
    
    public boolean isFull() {
        return this.uesdSize == this.elem.length;
    }
}

2.2 浪费一个数组空间来判断空满

class MyCircularQueue {
    private int[] elem;//由于不是泛型类,且依据题意放入数组中的数据都是int类型的,
                       //因此如此定义
    private int head;//队头位置
    private int last;//待插入数据位置

    public MyCircularQueue(int k) {
        this.elem = new int[k + 1];
    }
    
    //尾插
    public boolean enQueue(int value) {
        if (this.isFull()) {
            return false;
        }

        this.elem[this.last] = value;
        this.last++;
        //使得last的下标一直维持在0~elem.length-1
        this.last = this.last % this.elem.length;
        return true;
    }
    
    //头删
    public boolean deQueue() {
        if (this.isEmpty()) {
            return false;
        }

        //头删是让head的值++,而不是--🙀
        this.head++;
        this.head = this.head % this.elem.length;
        return true;    
    }
    
    //获取队头元素的值
    public int Front() {
        if (this.isEmpty()) {
            return -1;
        }

        return this.elem[this.head];
    }
    
    //获取队尾元素的值
    public int Rear() {
        if (this.isEmpty()) {
            return -1;
        }

        if (this.last == 0) {
            return this.elem[this.elem.length - 1];
        } 
        return this.elem[this.last - 1];
    }
    
    public boolean isEmpty() {
        return this.head == this.last;
    }
    
    public boolean isFull() {
        return (this.last + 1) % this.elem.length == this.head;//🙀,想一想特殊情况就知道为什么这么写了
    }
}

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

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

相关文章

mOTA v2.0

mOTA v2.0 一、简介 本开源工程是一款专为 32 位 MCU 开发的 OTA 组件&#xff0c;组件包含了 bootloader 、固件打包器 (Firmware_Packager) 、固件发送器 三部分&#xff0c;并提供了基于多款 MCU (STM32F1 / STM32F407 / STM32F411 / STM32L4) 和 YModem-1K 协议的案例。基…

【文献及模型、制图分享】2000—2020年中国青饲料播种面积及供需驱动因素的时空格局

文献介绍 高产、优质的青饲料对于国家畜牧业发展和食物供给至关重要。然而&#xff0c;当前对于青饲料播种面积时空变化格局及其阶段性特征、区域差异以及影响因素等尚未清楚。 本文基于省级面板数据分析了2000—2020年青饲料种植的时空格局变化&#xff0c;结合MODIS-NPP产品…

Nginx 405 not allowed

问题原因&#xff1a;nginx不允许静态文件被post请求 解决&#xff1a;添加error_page 405 200 $request_uri;

白酒与家庭:团圆时刻的需备佳品

在中国传统文化中&#xff0c;家庭是社会的基石&#xff0c;是每个人心灵的港湾。而团圆&#xff0c;则是家庭生活中较美好的时刻。在这样一个特殊的日子里&#xff0c;白酒&#xff0c;尤其是豪迈白酒&#xff08;HOMANLISM&#xff09;&#xff0c;成为了团圆时刻的需备佳品。…

了解JS数组元素及属性

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1、定义数组并输出2、查询数组的长度3、访问数组的第一个元素4、访问数组中第一个元素的xxx属性5、从数组元素中提取ID并存储到搜索参数对象 提示&#xff1a;以下是…

C++设计模式1:单例模式(懒汉模式和饿汉模式,以及多线程问题处理)

饿汉单例模式 程序还没有主动获取实例对象&#xff0c;该对象就产生了&#xff0c;也就是程序刚开始运行&#xff0c;这个对象就已经初始化了。 class Singleton { public:~Singleton(){std::cout << "~Singleton()" << std::endl;}static Singleton* …

KUKA KR C2 中文操作指南 详情见目录

KUKA KR C2 中文操作指南 详情见目录

Selenium + Python 自动化测试22(PO+数据驱动)

我们的目标是&#xff1a;按照这一套资料学习下来&#xff0c;大家可以独立完成自动化测试的任务。 上一篇我们讨论了PO模式和unittest框架结合起来使用。 本篇文章我们综合一下之前学习的内容&#xff0c;如先将PO模式、数据驱动思想和我们生成HTML报告融合起来&#xff0c;综…

​2024年AI新蓝海:三门生意如何借AI之力,开启变现新篇章

【导语】在这个日新月异的时代&#xff0c;人工智能&#xff08;AI&#xff09;已不再是遥不可及的未来科技&#xff0c;而是正逐步渗透到我们生活的方方面面&#xff0c;成为推动产业升级的重要力量。你是否还在为传统行业的未来而忧虑&#xff1f;别担心&#xff0c;AI正以其…

Pandas DataFrame 数据转换处理和多条件查询

工作中需要处理一个比较大的数据&#xff0c;且当中需要分析的日期类型字段为字符串型&#xff0c;需要进行转换&#xff0c;获得一个新的字段用于时间统计。我们应用 datetime.datetime.strptime 函数进行转换。 数据读取与时间列补充代码如下&#xff1a; import pandas as…

原来ChatGPT是这么评价《黑神话:悟空》的啊?

《黑神话&#xff1a;悟空》一经上线便迅速吸引了全球的目光&#xff0c;成为了今日微博热搜榜上的焦点话题。作为中国首款现象级的中国3A大作&#xff0c;它的发布无疑引发了广泛的关注与讨论。 《黑神话&#xff1a;悟空》&#xff0c;这款3A国产游戏大作&#xff0c;由国内游…

根据状态的不同,显示不同的背景颜色

文章目录 前言HTML模板部分JavaScript部分注意&#xff1a;主要差异影响如何处理示例 总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 实现效果&#xff1a; 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 根据给定的状态…

文件操作2(函数的专栏)

1、文件的打开和关闭 1.1文件指针 在缓冲文件系统中&#xff0c;关键的概念是“文件类型指针”&#xff0c;简称“文件指针”取名为FILE。 例如&#xff0c; VS2013编译环境提供的 stdio. h头文件中有以下的文件类型申明&#xff1a; struct _ iobuf { char *_ ptr; int _…

【YOLO5 项目实战】(6)YOLO5+StrongSORT 目标追踪

欢迎关注『youcans动手学模型』系列 本专栏内容和资源同步到 GitHub/youcans 【YOLO5 项目实战】&#xff08;1&#xff09;YOLO5 环境配置与检测 【YOLO5 项目实战】&#xff08;2&#xff09;使用自己的数据集训练目标检测模型 【YOLO5 项目实战】&#xff08;6&#xff09;Y…

数据库机器上停service360safe

发现有个数据库的负载较高&#xff0c;发现有360safe&#xff0c;就准备停了该服务再观察 [rootdb1 ~]# ps -ef |grep 360 root 970 1 0 15:12 ? 00:00:10 /opt/360safe/360entclient root 976 970 5 15:12 ? 00:18:42 /opt/360…

Linux之RabbitMQ集群部署

RabbitMQ 消息中间件 1、消息中间件 消息(message)&#xff1a; 指在服务之间传送的数据。可以是简单的文本消息&#xff0c;也可以是包含复杂的嵌入对象的消息 消息队列(message queue): 指用来存放消息的队列&#xff0c;一般采用先进先出的队列方式&#xff0c;即最先进入的…

关于springboot的异常处理以及源码分析(一)

一、什么是异常处理 1、文档定义 首先我们先来看springboot官方对于异常处理的定义。springboot异常处理 在文档的描述中&#xff0c;我们首先可以看到的一个介绍如下&#xff1a; By default, Spring Boot provides an /error mapping that handles all errors in a sensib…

优思学院|如何在30分钟内评审一家供应商?SQE必需知道的11点

在供应商评审中&#xff0c;特别是时间有限的情况下&#xff0c;SQE&#xff08;供应商质量工程师&#xff09;需要通过高效的观察和分析来快速评估供应商的能力。在《哈佛商业评论》中&#xff0c;R. Eugene Goodson 的一篇“Read a Plant—Fast”文章正好提供了一个极为实用的…

python实现指数平滑法进行时间序列预测

python实现指数平滑法进行时间序列预测 一、指数平滑法定义 1、指数平滑法是一种常用的时间序列预测算法,有一次、二次和三次平滑,通过加权系数来调整历史数据权重; 2、主要思想是:预测值是以前观测值的加权和,且对不同的数据给予不同的权数,新数据给予较大的权数,旧数…

基于x86 平台opencv的图像采集和seetaface6的人脸识别功能

目录 一、概述二、环境要求2.1 硬件环境2.2 软件环境三、开发流程3.1 编写测试3.2 配置资源文件3.2 验证功能一、概述 本文档是针对x86 平台opencv的图像采集和seetaface6的人脸识别功能,opencv通过读取本地图像,将采集的本地图像送给seetaface6的人脸识别模块从而实现人脸识…