Java中的queue和deque
2018-02-06 00:00
162 查看
摘要: queue deque 队列 双端队列
1、Queue
队列, 一种常用的数据结构,可以将队列看做是一种特殊的线性表,该结构遵循的先进先出原则。Java中,LinkedList实现了Queue接口,因为LinkedList进行插入、删除操作效率较高
相关方法:
boolean offer(E e):将元素追加到队列末尾,若添加成功则返回true。
E poll():从队首删除并返回该元素。
E peek():返回队首元素,但是不删除
示例:
运行结果:
[one, two, three, four]
one
[two, three, four]
two
[two, three, four]
two
three
four
2、Deque
双向队列,指该队列两端的元素既能入队(offer)也能出队(poll),如果将Deque限制为只能从一端入队和出队,则可实现栈的数据结构。对于栈而言,有入栈(push)和出栈(pop),遵循先进后出原则
常用方法如下:
void push(E e):将给定元素”压入”栈中。存入的元素会在栈首。即:栈的第一个元素
E pop():将栈首元素删除并返回。
示例:
运行结果:
[c, b, a]
c
[c, b, a]
c
b
a
[]
1、Queue
队列, 一种常用的数据结构,可以将队列看做是一种特殊的线性表,该结构遵循的先进先出原则。Java中,LinkedList实现了Queue接口,因为LinkedList进行插入、删除操作效率较高
相关方法:
boolean offer(E e):将元素追加到队列末尾,若添加成功则返回true。
E poll():从队首删除并返回该元素。
E peek():返回队首元素,但是不删除
示例:
public class QueueDemo { public static void main(String [] args) { Queue<String> queue = new LinkedList<String>(); //追加元素 queue.offer("one"); queue.offer("two"); queue.offer("three"); queue.offer("four"); System.out.println(queue); //从队首取出元素并删除 String poll = queue.poll(); System.out.println(poll); System.out.println(queue); //从队首取出元素但是不删除 String peek = queue.peek(); System.out.println(peek); System.out.println(queue); //遍历队列,这里要注意,每次取完元素后都会删除,整个 //队列会变短,所以只需要判断队列的大小即可 while(queue.size() > 0) { System.out.println(queue.poll()); } } }
运行结果:
[one, two, three, four]
one
[two, three, four]
two
[two, three, four]
two
three
four
2、Deque
双向队列,指该队列两端的元素既能入队(offer)也能出队(poll),如果将Deque限制为只能从一端入队和出队,则可实现栈的数据结构。对于栈而言,有入栈(push)和出栈(pop),遵循先进后出原则
常用方法如下:
void push(E e):将给定元素”压入”栈中。存入的元素会在栈首。即:栈的第一个元素
E pop():将栈首元素删除并返回。
示例:
public class DequeDemo { public static void main(String[] args) { Deque<String> deque = new LinkedList<String>(); deque.push("a"); deque.push("b"); deque.push("c"); System.out.println(deque); //获取栈首元素后,元素不会出栈 String str = deque.peek(); System.out.println(str); System.out.println(deque); while(deque.size() > 0) { //获取栈首元素后,元素将会出栈 System.out.println(deque.pop()); } System.out.println(deque); } }
运行结果:
[c, b, a]
c
[c, b, a]
c
b
a
[]
相关文章推荐
- JAVA学习笔记43——其他容器简介1:Queue+Deque+Enumeration
- Java 队列 Queue、Deque、AbstractQueue 源码分析
- java队列学习 deque和queue
- java 中的Stack、Queue、Deque
- Java多线程 -- JUC包源码分析5 -- Condition/ArrayBlockingQueue/LinkedBlockingQueue/Deque/PriorityBlockingQueue
- Java集合之Queue和Deque接口
- java的queue和deque
- Java队列Queue、双端队列Deque
- java队列Queue、双端队列Deque
- Java中的queue和deque
- Java集合(13)——Queue与Deque源码解析
- Java源码心中有数系列 BlockingQueue / BlockingDeque
- Java中的queue和deque对比详解
- Java中Queue和Deque的接口说明
- Java中的queue和deque
- java09 队列Queue与Deque
- Java多线程 -- JUC包源码分析5 -- Condition/ArrayBlockingQueue/LinkedBlockingQueue/Deque/PriorityBlockingQueu
- Queue AbstractQueue Deque 源代码
- STL之queue队列 stack栈 priority_queue优先队列 deque双向队列
- BlockingQueue and BlockingDeque