当前位置: 首页 > news >正文

数据结构(队列)

一.什么是队列

1.队列定义

        队列是一种特殊的线性表,特殊之处在于他只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。和栈一样,队列也是一种操作受限制的线性表。进行插入操作的一端称为队尾,进行删除操作的一端称为队头或者队首。

2.队列特点

        ①   队列中的元素满足先进先出(FIFO)的特点,即先进入队列的元素总是最先从队列移出。这种特点使得队列在处理数据时具有优势,能够高效地组织和管理进程。同时,先进先出也保证了队列中元素的顺序稳定,避免了一些特护情况下的数据丢失。

        ② 限制插入和删除操作:队列只允许在队尾插入元素,在队头删除元素。

        ③ 应用广泛:队列在计算机领域中应用广泛,如操作系统、网络通信、数据压缩等,在实际生活中,排队买票、办理业务等也可以用队列来模拟和处理。

二.队列的基本操作 

1.首先定义一个队列接口,编写队列的几种基本操作

public interface myQueue<T> {// 入队void offer(T val);// 出队T poll();// 查看队首元素T getFront();// 获取当前队列中的元素个数int getSize();// 判断队列是否为空boolean isEmpty();}

2.我们创建一个类去实现我们自己撰写的接口

// 以数组为队列的数据存储结构
public class ArrOrdQueue<T> implements myQueue<T> {private MyArray<T> data;int size;public ArrOrdQueue() {this.data = new MyArray<>(100);this.size = 0;}@Overridepublic void offer(T val) {this.data.add(val);this.size++;}@Overridepublic T poll() {if(isEmpty()){return null;}return this.data.removeFromLast();}@Overridepublic T getFront() {if(isEmpty()){return null;}return this.data.getValue();}@Overridepublic int getSize() {return this.data.getSize();}@Overridepublic boolean isEmpty() {return this.data.isEmpty();}}

 3.入队操作

    // 添加元素public void add(T item) {this.arr[this.size] = item;this.size++;}

4. 判断队列是否为空

    // 判空public boolean isEmpty() {return this.size == 0;}

5.出队操作

    public T removeFromLast() {T delVal = this.arr[this.size - 1];this.size--;return delVal;}

6. 查看当前队头元素

    public T getValue() {return getValueByIndex(this.size - 1);}// 获取指定位置的值public T getValueByIndex(int index) {// 入参判断if (index < 0 || index > capacity) {throw new IllegalArgumentException("索引异常!");}return this.arr[index];}

7.获取当前队列中元素的个数

    // 获取元素个数public int getSize() {return this.size;}

 三.队列的应用

        ① 图的遍历算法中的广度优先搜索就可以用队列辅助。

        ② 可用于计算机的模拟。

        ③ 可作为CPU的作业调度。使用队列来处理,可实现先到先执行的要求

        

http://www.lryc.cn/news/288429.html

相关文章:

  • docker容器启动后修改或添加端口 nacos容器 版本2.x需要额外开放9848、9849
  • C语言实现归并排序算法(附带源代码)
  • 考研C语言刷题基础篇之分支循环结构基础(二)
  • Scala基础知识
  • 数学建模-------误差来源以及误差分析
  • Arduino和MPLAB X 开发STM32F103和PIC16F15376
  • 手机操作系统Android
  • 2024年,你是否还在迷茫?
  • ART: Automatic multi-step reasoning and tool-use for large language models 导读
  • Github 2024-01-26 开源项目日报Top10
  • 免费的 UI 设计资源网站 Top 8
  • 人机协同对人工智能治理的影响
  • Form.List的使用,设置某个字段的值
  • React16源码: React中的updateHostComponent的源码实现
  • uniapp导入uView组件库
  • 防御保护----防火墙的安全策略、NAT策略实验
  • # 安徽锐锋科技IDMS系统简介
  • Notepad在文件中查找多行相同内容的文字
  • Python高超音速导弹
  • Java七大排序详解
  • 图像旋转角度计算并旋转
  • 通过curl访问k8s集群获取证书或token的方式
  • 苍穹外卖-前端部分(持续更新中)
  • windows用mingw(g++)编译opencv,opencv_contrib,并install安装
  • JDWP 协议及实现
  • 利用ADS建立MIPI D-PHY链路仿真流程
  • 【大根堆】【C++算法】871 最低加油次数
  • SpringBoot的自动装配原理
  • 嵌入式驱动开发需要会哪些技能?
  • Leetcode:二分搜索树层次遍历