0

0

java代码如何实现队列的双端操作 java代码双端队列的基础实现技巧​

看不見的法師

看不見的法師

发布时间:2025-08-16 17:43:01

|

308人浏览过

|

来源于php中文网

原创

双端队列可在两端进行插入和删除操作,Java中通过实现Deque接口支持该结构,常用ArrayDeque(基于数组,访问快)和LinkedList(基于链表,增删快)实现,前者适用于元素数量固定且访问频繁的场景,后者适合频繁增删且容量变化大的场景;二者在性能上主要差异在于访问速度与内存占用,选择需根据具体需求权衡;此外,还可通过自定义数组、循环数组或第三方库实现双端队列,以满足特定性能或功能要求。

java代码如何实现队列的双端操作 java代码双端队列的基础实现技巧​

双端队列,顾名思义,就是可以在队列的两端进行插入和删除操作的数据结构。Java中

java.util.Deque
接口提供了双端队列的功能。实现双端队列,本质上就是实现这个接口。

解决方案

Java中,可以使用

ArrayDeque
LinkedList
来实现
Deque
接口。
ArrayDeque
基于数组实现,更高效,但容量有限制。
LinkedList
基于链表实现,容量理论上无限制,但效率稍低。

使用 ArrayDeque 实现双端队列:

立即学习Java免费学习笔记(深入)”;

import java.util.ArrayDeque;
import java.util.Deque;

public class ArrayDequeExample {

    public static void main(String[] args) {
        Deque deque = new ArrayDeque<>();

        // 从队头添加元素
        deque.addFirst("Element 1");
        deque.offerFirst("Element 0"); // offerFirst不会抛出异常,如果队列满了会返回false

        // 从队尾添加元素
        deque.addLast("Element 2");
        deque.offerLast("Element 3");

        System.out.println("Deque: " + deque); // 输出: Deque: [Element 0, Element 1, Element 2, Element 3]

        // 从队头移除元素
        String first = deque.removeFirst(); // 如果队列为空,会抛出NoSuchElementException
        String firstOrNull = deque.pollFirst(); // 如果队列为空,返回null

        // 从队尾移除元素
        String last = deque.removeLast(); // 如果队列为空,会抛出NoSuchElementException
        String lastOrNull = deque.pollLast(); // 如果队列为空,返回null

        System.out.println("Removed first: " + first); // 输出: Removed first: Element 0
        System.out.println("Removed last: " + last); // 输出: Removed last: Element 3
        System.out.println("Deque after removals: " + deque); // 输出: Deque after removals: [Element 1, Element 2]

        // 检查队列头部元素但不移除
        String peekFirst = deque.peekFirst();
        String getFirst = deque.getFirst();

        // 检查队列尾部元素但不移除
        String peekLast = deque.peekLast();
        String getLast = deque.getLast();

        System.out.println("Peek First: " + peekFirst); // 输出: Peek First: Element 1
        System.out.println("Peek Last: " + peekLast); // 输出: Peek Last: Element 2
    }
}

使用 LinkedList 实现双端队列:

import java.util.Deque;
import java.util.LinkedList;

public class LinkedListDequeExample {

    public static void main(String[] args) {
        Deque deque = new LinkedList<>();

        deque.addFirst("A");
        deque.addLast("B");
        deque.push("C"); // 等价于 addFirst
        deque.offer("D"); // 等价于 addLast

        System.out.println("Deque: " + deque); // 输出: Deque: [C, A, B, D]

        System.out.println("Removed first: " + deque.removeFirst()); // 输出: Removed first: C
        System.out.println("Removed last: " + deque.removeLast()); // 输出: Removed last: D
        System.out.println("Deque after removals: " + deque); // 输出: Deque after removals: [A, B]

        System.out.println("Peek first: " + deque.peekFirst()); // 输出: Peek first: A
        System.out.println("Peek last: " + deque.peekLast()); // 输出: Peek last: B

    }
}

双端队列相比普通队列的优势是什么?应用场景有哪些?

双端队列最大的优势在于灵活性。普通队列只能在一端插入,另一端删除,而双端队列两端都可以进行插入和删除。这种灵活性使得双端队列可以应用于更多场景。

UP简历
UP简历

基于AI技术的免费在线简历制作工具

下载

应用场景:

  • 回溯算法: 在回溯算法中,需要在搜索路径上进行前进和后退的操作,双端队列可以方便地实现这些操作。比如,网页浏览器的前进后退功能就可以用双端队列实现。
  • 任务调度: 可以根据任务的优先级,将高优先级任务插入到队头,低优先级任务插入到队尾。
  • 数据缓存: 可以使用双端队列来实现LRU(Least Recently Used)缓存。最近使用的数据放在队头,最久未使用的数据放在队尾,当缓存满时,从队尾移除数据。
  • 解析器: 在某些解析器中,需要同时从头和尾处理数据。

ArrayDeque 和 LinkedList 在实现双端队列时,性能上有哪些差异?如何选择?

ArrayDeque
LinkedList
在实现
Deque
接口时,底层数据结构不同,导致性能差异。

  • ArrayDeque: 基于动态数组实现。
    • 优点: 访问元素速度快(O(1)),因为数组在内存中是连续存储的。在已知元素数量的情况下,内存占用更少。
    • 缺点: 插入和删除元素时,可能需要移动其他元素,时间复杂度为O(n)。扩容时需要复制整个数组,开销较大。
  • LinkedList: 基于链表实现。
    • 优点: 插入和删除元素速度快(O(1)),只需要修改指针即可。容量理论上无限制。
    • 缺点: 访问元素速度慢(O(n)),需要从头或尾遍历链表。每个元素都需要额外的空间存储指针,内存占用较多。

如何选择:

  • 如果需要频繁访问队列中的元素,且对内存占用比较敏感,选择
    ArrayDeque
  • 如果需要频繁插入和删除元素,且对内存占用不敏感,选择
    LinkedList
  • 如果事先知道队列的元素数量,且元素数量变化不大,选择
    ArrayDeque
  • 如果队列的元素数量变化很大,且无法预知,选择
    LinkedList

举个例子,假设你需要实现一个LRU缓存,缓存大小固定,且访问频率很高,那么

ArrayDeque
可能更适合。如果缓存大小不固定,且插入和删除操作频繁,那么
LinkedList
可能更适合。

除了 ArrayDeque 和 LinkedList,还有没有其他方式实现双端队列?

理论上,任何可以支持两端插入和删除操作的数据结构都可以用来实现双端队列。

  • 自定义数组实现: 可以自己实现一个基于数组的双端队列,通过维护两个指针,分别指向队头和队尾,来实现两端的插入和删除。这种方式可以更加灵活地控制内存使用和性能,但需要更多的代码实现。
  • 循环数组: 使用循环数组可以更有效地利用空间,避免数组扩容带来的开销。通过取模运算来确定队头和队尾的位置。
  • 使用第三方库: 一些第三方库可能提供了更高级的双端队列实现,例如并发安全的双端队列。

选择哪种方式取决于具体的应用场景和需求。如果对性能有极致的要求,可能需要自定义实现。如果只是需要简单的双端队列功能,使用

ArrayDeque
LinkedList
即可。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

832

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

737

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

734

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

34

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.7万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 2.5万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号