search
HomeJavajavaTutorialHow to use Deque function in Java for deque operations

Double-ended queue (Deque) is a relatively complex data structure with queue and stack characteristics. It supports all operations of queues and stacks, and can add or delete elements at the head and tail of the queue. In Java, Deque is an interface, which has two implementation classes: ArrayDeque and LinkedList.

This article will introduce how to use the Deque function in Java to perform double-ended queue operations, including creating Deque, adding elements, removing elements, head and tail operations, etc.

1. Create Deque

To create a Deque object in Java, you can use the ArrayDeque or LinkedList implementation class. If the number of elements is known and performance requirements are high, it is better to use ArrayDeque; if the number of elements is uncertain, or elements need to be frequently inserted or deleted in the middle, it is better to use LinkedList.

The following is the code to create a Deque object named deque:

Deque<String> deque = new ArrayDeque<String>(); // 使用ArrayDeque实现类创建
Deque<Integer> deque = new LinkedList<Integer>(); // 使用LinkedList实现类创建

2. Add elements

Adding elements is one of the basic operations of a double-ended queue. In Deque, elements can be added to the head or tail of the queue. Use the addFirst() and addLast() methods respectively to add.

Use addFirst() to add elements:

deque.addFirst("element");

Use addLast() to add elements:

deque.addLast("element");

If the double-ended queue is full during the addition process, addFirst() will throw An IllegalStateException occurs.

3. Remove elements

Removing elements is also one of the basic operations of a double-ended queue. In Deque, you can also remove elements from the head or tail of the queue. Use the removeFirst() and removeLast() methods respectively to remove.

Use removeFirst() to remove elements:

String element = deque.removeFirst();

Use removeLast() to remove elements:

String element = deque.removeLast();

If the queue is empty, calling the above method will throw a NoSuchElementException exception.

4. Determine elements

Sometimes we need to determine whether the Deque contains a certain element or what the first and last elements are. At this time, you can use element(), peek() and other methods.

Use element() to get the first element of the team:

String firstElement = deque.element(); // 队首元素

Use peek() to get the first element of the team:

String firstElement = deque.peek(); // 队首元素

If the queue is empty, calling the above method will throw NoSuchElementException abnormal.

Use peekFirst() to get the first element of the team:

String firstElement = deque.peekFirst(); // 队首元素

Use peekLast() to get the last element of the team:

String lastElement = deque.peekLast(); // 队尾元素

5. Traversing elements

During traversal For elements in Deque, you can use Iterator, foreach or lambda expressions to perform traversal operations.

Traverse using Iterator:

Iterator<String> iterator = deque.iterator(); // 获取Iterator对象
while (iterator.hasNext()) { // 依次输出元素
    System.out.println(iterator.next());
}

Traverse using foreach:

for (String element : deque) { // 依次输出元素
    System.out.println(element);
}

Traverse using lambda expression:

deque.forEach(element -> System.out.println(element)); // 依次输出元素

Summary

Deque is The interface of double-ended queue in Java provides all operations of queue and stack. You can add or delete elements at the head of the queue and add or delete elements at the tail of the queue. In Java, Deque has two implementation classes: ArrayDeque and LinkedList, which are used in different scenarios.

This article introduces how to use the Deque function in Java to perform double-ended queue operations, including creating Deque, adding elements, removing elements, head and tail operations, and traversing elements. Dedicated to providing help to Java beginners, more articles are on this site!

The above is the detailed content of How to use Deque function in Java for deque operations. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
JVM performance vs other languagesJVM performance vs other languagesMay 14, 2025 am 12:16 AM

JVM'sperformanceiscompetitivewithotherruntimes,offeringabalanceofspeed,safety,andproductivity.1)JVMusesJITcompilationfordynamicoptimizations.2)C offersnativeperformancebutlacksJVM'ssafetyfeatures.3)Pythonisslowerbuteasiertouse.4)JavaScript'sJITisles

Java Platform Independence: Examples of useJava Platform Independence: Examples of useMay 14, 2025 am 12:14 AM

JavaachievesplatformindependencethroughtheJavaVirtualMachine(JVM),allowingcodetorunonanyplatformwithaJVM.1)Codeiscompiledintobytecode,notmachine-specificcode.2)BytecodeisinterpretedbytheJVM,enablingcross-platformexecution.3)Developersshouldtestacross

JVM Architecture: A Deep Dive into the Java Virtual MachineJVM Architecture: A Deep Dive into the Java Virtual MachineMay 14, 2025 am 12:12 AM

TheJVMisanabstractcomputingmachinecrucialforrunningJavaprogramsduetoitsplatform-independentarchitecture.Itincludes:1)ClassLoaderforloadingclasses,2)RuntimeDataAreafordatastorage,3)ExecutionEnginewithInterpreter,JITCompiler,andGarbageCollectorforbytec

JVM: Is JVM related to the OS?JVM: Is JVM related to the OS?May 14, 2025 am 12:11 AM

JVMhasacloserelationshipwiththeOSasittranslatesJavabytecodeintomachine-specificinstructions,managesmemory,andhandlesgarbagecollection.ThisrelationshipallowsJavatorunonvariousOSenvironments,butitalsopresentschallengeslikedifferentJVMbehaviorsandOS-spe

Java: Write Once, Run Anywhere (WORA) - A Deep Dive into Platform IndependenceJava: Write Once, Run Anywhere (WORA) - A Deep Dive into Platform IndependenceMay 14, 2025 am 12:05 AM

Java implementation "write once, run everywhere" is compiled into bytecode and run on a Java virtual machine (JVM). 1) Write Java code and compile it into bytecode. 2) Bytecode runs on any platform with JVM installed. 3) Use Java native interface (JNI) to handle platform-specific functions. Despite challenges such as JVM consistency and the use of platform-specific libraries, WORA greatly improves development efficiency and deployment flexibility.

Java Platform Independence: Compatibility with different OSJava Platform Independence: Compatibility with different OSMay 13, 2025 am 12:11 AM

JavaachievesplatformindependencethroughtheJavaVirtualMachine(JVM),allowingcodetorunondifferentoperatingsystemswithoutmodification.TheJVMcompilesJavacodeintoplatform-independentbytecode,whichittheninterpretsandexecutesonthespecificOS,abstractingawayOS

What features make java still powerfulWhat features make java still powerfulMay 13, 2025 am 12:05 AM

Javaispowerfulduetoitsplatformindependence,object-orientednature,richstandardlibrary,performancecapabilities,andstrongsecurityfeatures.1)PlatformindependenceallowsapplicationstorunonanydevicesupportingJava.2)Object-orientedprogrammingpromotesmodulara

Top Java Features: A Comprehensive Guide for DevelopersTop Java Features: A Comprehensive Guide for DevelopersMay 13, 2025 am 12:04 AM

The top Java functions include: 1) object-oriented programming, supporting polymorphism, improving code flexibility and maintainability; 2) exception handling mechanism, improving code robustness through try-catch-finally blocks; 3) garbage collection, simplifying memory management; 4) generics, enhancing type safety; 5) ambda expressions and functional programming to make the code more concise and expressive; 6) rich standard libraries, providing optimized data structures and algorithms.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),