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

Java 数据结构 队列之双端队列 常用方法 示例代码 及其实现

目录

常用方法

示例代码

常见实现


Java中的双端队列(Deque,Double Ended Queue)是一种队列,它允许在队列的两端插入和删除元素。与普通队列(FIFO)不同,双端队列的元素可以从队列的两端进行添加或删除。

Java提供了Deque接口,它扩展了Queue接口,常见的实现类有ArrayDequeLinkedList

常用方法

Deque接口支持以下常见操作:

  • 添加元素
    • addFirst(E e):将元素添加到队列的前端。
    • addLast(E e):将元素添加到队列的末端。
  • 删除元素
    • removeFirst():删除队列前端的元素。
    • removeLast():删除队列末端的元素。
    • pollFirst():删除并返回队列前端的元素(如果队列为空返回null)。
    • pollLast():删除并返回队列末端的元素(如果队列为空返回null)。
  • 查看元素
    • getFirst():查看队列前端的元素。
    • getLast():查看队列末端的元素。
    • peekFirst():查看队列前端的元素(如果队列为空返回null)。
    • peekLast():查看队列末端的元素(如果队列为空返回null)。

示例代码

java复制代码
import java.util.Deque;
import java.util.ArrayDeque;public class DequeExample {public static void main(String[] args) {Deque<Integer> deque = new ArrayDeque<>();// 添加元素deque.addFirst(10); // 队头添加元素deque.addLast(20);  // 队尾添加元素deque.addLast(30);// 查看元素System.out.println("队头元素: " + deque.getFirst());  // 输出 10System.out.println("队尾元素: " + deque.getLast());   // 输出 30// 删除元素System.out.println("删除队头元素: " + deque.removeFirst()); // 输出 10System.out.println("删除队尾元素: " + deque.removeLast());  // 输出 30// 再次查看元素System.out.println("队头元素: " + deque.getFirst());  // 输出 20}
}

常见实现

  1. ArrayDeque:基于数组实现的双端队列,性能较好,适用于大多数场景,不支持null元素。
  2. LinkedList:基于双向链表实现,提供较高的灵活性,支持更多的操作,但相较于ArrayDeque性能略低。

你可以根据不同的需求选择使用这两个实现。

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

相关文章:

  • 【原创】大数据治理入门(2)《提升数据质量:质量评估与改进策略》入门必看 高赞实用
  • arcgis中生成格网矢量带高度
  • 使用gtsam添加OrientedPlane3Factor平面约束因子
  • 换了城市ip属地会变吗?为什么换了城市IP属地不变
  • 移远通信多模卫星通信模组BG95-S5获得Skylo网络认证,进一步拓展全球卫星物联网市场
  • IntelliJ IDEA Type Hierarchy Scope Pattern 学习指南
  • 简聊MySQL并发事务中幻读、虚读问题的解决方案
  • 【搭建JavaEE】(2)Tomcat安装配置和第一个JavaEE程序
  • 【Qt】01-了解QT
  • websocket股票行情接口
  • 朴素贝叶斯分类器
  • 智能化植物病害检测:使用深度学习与图像识别技术的应用
  • vim基本命令(vi、工作模式、普通模式、插入模式、可视模式、命令行模式、复制、粘贴、插入、删除、查找、替换)
  • Qt 自动根据编译的dll或exe 将相关dll文件复制到目标文件夹
  • 探索新能源汽车“芯”动力:AUTO TECH China 2025广州国际新能源汽车功率半导体技术展盛况空前
  • Kafka权威指南(第2版)读书笔记
  • WORD转PDF脚本文件
  • electron 打包后的 exe 文件,运行后是空白窗口
  • 数据库重连 - 方案
  • 从 PostgreSQL 中挽救损坏的表
  • 【Vue3 入门到实战】1. 创建Vue3工程
  • rtthread学习笔记系列(10/11) -- 系统定时器
  • mock服务-通过json定义接口自动实现mock服务
  • 像JSONDecodeError: Extra data: line 2 column 1 (char 134)这样的问题怎么解决
  • C#版 软件开发6大原则与23种设计模式
  • java8 springboot 集成javaFx 实现一个客户端程序
  • MySQL(高级特性篇) 06 章——索引的数据结构
  • PanWeidb-使用BenchmarkSQL对磐维数据库进行压测
  • AR 在高校实验室安全教育中的应用
  • 微信小程序实现个人中心页面