`
duyouhua1214
  • 浏览: 230674 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Deque 作为堆栈使用(ArrayDeque)

    博客分类:
  • Java
阅读更多
package code.jdk;   
  1. import java.util.ArrayDeque;   
  2. import java.util.Deque;   
  3. public class IntegerStack {   
  4.   private Deque<Integer> data = new ArrayDeque<Integer>();   
  5.   public void push(Integer element) {   
  6.     data.addFirst(element);   
  7.   }   
  8.   public Integer pop() {   
  9.     return data.removeFirst();   
  10.   }   
  11.   public Integer peek() {   
  12.     return data.peekFirst();   
  13.   }   
  14.   public String toString() {   
  15.     return data.toString();   
  16.   }   
  17.   public static void main(String[] args) {   
  18.     IntegerStack stack = new IntegerStack();   
  19.     for (int i = 0; i < 5; i++) {   
  20.       stack.push(i);   
  21.     }   
  22.     System.out.println("After pushing 5 elements: " + stack);   
  23.     int m = stack.pop();   
  24.     System.out.println("Popped element = " + m);   
  25.     System.out.println("After popping 1 element : " + stack);   
  26.     int n = stack.peek();   
  27.     System.out.println("Peeked element = " + n);   
  28.     System.out.println("After peeking 1 element : " + stack);   
  29.   }   
  30. }  
 
package code.jdk;
import java.util.ArrayDeque;
import java.util.Deque;
public class IntegerStack {
  private Deque<Integer> data = new ArrayDeque<Integer>();
  public void push(Integer element) {
    data.addFirst(element);
  }
  public Integer pop() {
    return data.removeFirst();
  }
  public Integer peek() {
    return data.peekFirst();
  }
  public String toString() {
    return data.toString();
  }
  public static void main(String[] args) {
    IntegerStack stack = new IntegerStack();
    for (int i = 0; i < 5; i++) {
      stack.push(i);
    }
    System.out.println("After pushing 5 elements: " + stack);
    int m = stack.pop();
    System.out.println("Popped element = " + m);
    System.out.println("After popping 1 element : " + stack);
    int n = stack.peek();
    System.out.println("Peeked element = " + n);
    System.out.println("After peeking 1 element : " + stack);
  }
}



运行结果

After pushing 5 elements: [43210]   
  1. Popped element = 4  
  2. After popping 1 element : [3210]   
  3. Peeked element = 3  
  4. After peeking 1 element : [3210]  
After pushing 5 elements: [4, 3, 2, 1, 0]
Popped element = 4
After popping 1 element : [3, 2, 1, 0]
Peeked element = 3
After peeking 1 element : [3, 2, 1, 0]



Deque 的API说明
public interface Deque<E>extends Queue<E>一个线性 collection,支持在两端插入和移除元素。名称 deque 是“double ended queue(双端队列)”的缩写,通常读为“deck”。大多数 Deque 实现对于它们能够包含的元素数没有固定限制,但此接口既支持有容量限制的双端队列,也支持没有固定大小限制的双端队列。 此接口定义在双端队列两端访问元素的方法。提供插入、移除和检查元素的方法。每种方法都存在两种形式:一种形式在操作失败时抛出异常,另一种形式返回一个特殊值(null 或 false,具体取决于操作)。插入操作的后一种形式是专为使用有容量限制的 Deque 实现设计的;在大多数实现中,插入操作不能失败。 下表总结了上述 12 种方法:

  第一个元素(头部) 最后一个元素(尾部)
  抛出异常 特殊值 抛出异常 特殊值
插入 addFirst(e) offerFirst(e) addLast(e) offerLast(e)
移除 removeFirst() pollFirst() removeLast() pollLast()
检查 getFirst() peekFirst() getLast() peekLast()

此接口扩展了 Queue 接口。在将双端队列用作队列时,将得到 FIFO(先进先出)行为。将元素添加到双端队列的末尾,从双端队列的开头移除元素。从 Queue 接口继承的方法完全等效于 Deque 方法,如下表所示:

Queue 方法 等效 Deque 方法
add(e) addLast(e)
offer(e) offerLast(e)
remove() removeFirst()
poll() pollFirst()
element() getFirst()
peek() peekFirst()

双端队列也可用作 LIFO(后进先出)堆栈。应优先使用此接口而不是遗留 Stack 类。在将双端队列用作堆栈时,元素被推入双端队列的开头并从双端队列开头弹出。堆栈方法完全等效于 Deque 方法,如下表所示:

堆栈方法 等效 Deque 方法
push(e) addFirst(e)
pop() removeFirst()
peek() peekFirst()

注意,在将双端队列用作队列或堆栈时,peek 方法同样正常工作;无论哪种情况下,都从双端队列的开头抽取元素。 此接口提供了两种移除内部元素的方法:removeFirstOccurrenceremoveLastOccurrence。 与 List 接口不同,此接口不支持通过索引访问元素。 虽然 Deque 实现没有严格要求禁止插入 null 元素,但建议最好这样做。建议任何事实上允许 null 元素的 Deque 实现用户最好 要利用插入 null 的功能。这是因为各种方法会将 null 用作特殊的返回值来指示双端队列为空。 Deque 实现通常不定义基于元素的 equals 和 hashCode 方法,而是从 Object 类继承基于身份的 equals 和 hashCode 方法。 此接口是 Java Collections Framework 的成员。

 

来源:http://www.java2000.net/p624

分享到:
评论

相关推荐

    Java使用Deque实现堆栈的方法

    Deque(双端队列)不仅可以作为堆栈使用,还能作为队列,提供了更多的操作方法。 `Deque`接口继承自`Queue`接口,提供了在两端添加和移除元素的能力。在Java中,`ArrayDeque`是`Deque`的一个高效实现,它是无界的,...

    java程序设计一堆栈

    2. `java.util.Deque`接口:提供了一种更通用的数据结构,可以作为双端队列使用,包括ArrayDeque和LinkedList的实现。ArrayDeque在性能上通常优于LinkedList,尤其在并发环境中。 3. 自定义数据结构:通过继承...

    压堆栈算法

    在Java中,我们可以使用ArrayDeque、LinkedList或者自定义类来实现堆栈。 【描述】: 该描述中提到的链接可能指向一篇关于堆栈算法实际应用的文章,但具体内容没有提供。通常,堆栈算法的实现涉及以下几个关键操作...

    java堆栈类使用实例(java中stack的使用方法)

    但在性能要求较高的情况下,可能需要考虑使用非同步的替代品,如`Deque`接口的实现,如`ArrayDeque`。 - Stack类基于Vector实现,因此它的操作效率相对较低,因为Vector的大多数操作都有同步锁。在单线程环境中,...

    Stack-Programming:堆栈编程=独特的问题解决

    不过,在性能敏感的应用中,更倾向于使用ArrayList的子类java.util.Deque,如ArrayDeque,因为它们通常提供更好的性能。 堆栈编程的核心在于利用堆栈的特性来解决问题。以下是一些典型的应用场景: 1. **递归算法*...

    Java写的一个进栈出栈的演示程序

    另一种方法是利用`java.util.Deque`接口,特别是`ArrayDeque`类,它是一个高效的双端队列,可以作为栈使用。`ArrayDeque`相比于`Stack`在性能上更优,因为它避免了`Vector`的同步开销。 本程序的"汪秋云 MyStack....

    JavaSourceCodeAnalysis:JDK二进制阅读笔记,包括Java常用集合类和Java常用和发工具(同步工具,线程安全集合,线程池)两个部分-java source code analysis

    LinkedList还实现了Deque接口,可以作为单向和双向实例。 堆栈继承自向量,提供基础的堆栈操作。其保障线程安全的手段是使用同步的包装所有函数,和其他线程安全的集合比起来,在多线程环境中效率很低。 ...

    JavaExamples2快速点击·所有集合源代码

    - `Queue`代表先进先出(FIFO)的数据结构,如`LinkedList`可作为队列使用。 - `Deque`(双端队列)扩展了`Queue`,允许在两端添加和移除元素,如`ArrayDeque`。 5. **Stack** - `Stack`是`Vector`的一个子类,...

    java算法实战设计与分析

    队列是一种先进先出(FIFO)的数据结构,Java中可以使用LinkedList或ArrayDeque来实现。队列常用于任务调度、事件处理和多线程环境中的同步。例如,Java的Queue接口提供了offer()用于添加元素,poll()用于移除并返回...

    JAVA 容器类应用

    `ArrayDeque`是一个双端队列,可以作为栈或队列使用。`PriorityQueue`则根据元素的优先级进行排序,常用于调度任务。 容器类还包含`Stack`,它是后进先出(LIFO)的数据结构,模仿了传统的堆栈。`Deque`接口扩展了`...

    Java中Vector类和Stack类的学习_.docx

    对于栈操作,可以考虑使用`java.util.Stack`的替代品`Deque`接口的实现,如`ArrayDeque`,它在单线程环境下的性能更优。尽管如此,理解`Vector`和`Stack`的工作原理仍然对学习Java集合框架的历史和并发编程概念具有...

    数据结构基础

    更好的实现方式是双端队列(deque),例如使用ArrayDeque或LinkedList。 哈希表(或称字典)提供了一种通过键(key)快速查找值(value)的数据结构。JavaScript的Object就是一种哈希表,通过键值对存储数据,查找...

    JAVA容器效率深度分析List

    以及Deque接口的实现,如ArrayDeque,它是高效的双端队列,支持在两端添加和移除元素,适用于实现堆栈、队列或双端队列。 在分析和优化容器效率时,我们需要考虑以下几个关键因素: 1. **容量**:初始容量和扩容...

    data-structure-test:整理数据结构概念

    Java的LinkedList可以作为队列使用,还有专门的Queue接口和其实现类如ArrayDeque。 树形数据结构中,二叉树是最常见的。在二叉树中,每个节点最多有两个子节点,分为左子节点和右子节点。二叉搜索树是一种特殊的...

    java多线程解决消息压入栈和取出

    在Java中,我们可以使用`java.util.Stack`类或者`java.util.Deque`接口的实现,如`ArrayDeque`,来创建和操作栈。 消息队列(Message Queue)是另一种常见的并发编程工具,它能有效地协调多个线程之间的通信。消息...

    dataStructure:数据结构学习(主要用Java语言实现相关数据结构及其操作)

    10. **堆栈和队列的组合**:如双端队列(Deque),Java的java.util.Deque接口及其实现类ArrayDeque可以提供这种功能。 每个数据结构都有其特定的插入、删除、查找等操作的复杂度,理解和掌握它们的特性是优化算法的...

    全面接触Java集合框架

    - `Deque`:双端队列,支持在两端进行插入和删除,`ArrayDeque`是其非阻塞实现。 了解和熟练掌握Java集合框架对于编写高效的Java程序至关重要,这包括选择适当的集合类型、理解不同实现的性能特征以及正确使用并发...

    java-util包资料

    - **Deque**: 双端队列,可以作为队列或栈使用。 - **Stack**: 继承自Vector,实现后进先出(LIFO)的栈操作。 7. **并发工具类**: - **ConcurrentHashMap**: 并发友好的哈希映射,线程安全且高效。 - **...

    Stack

    在实际编程中,除了`java.util.Stack`,Java集合框架还提供了`Deque`接口(双端队列),它支持在两端进行插入和删除操作,`ArrayDeque`是其高效实现,也可作为栈使用。相比`Stack`,`ArrayDeque`通常具有更好的性能...

    Data_Structures

    Kotlin的LinkedList也可以作为双端队列使用。 6. 树(Tree) 树是一种非线性的数据结构,由节点(包含数据和指向子节点的引用)组成。二叉树是最简单的形式,每个节点最多有两个子节点。Kotlin的标准库没有直接提供...

Global site tag (gtag.js) - Google Analytics