#Java教程:双端队列-Deque @FDDLC
发布日期:2021-06-30 20:58:25
浏览次数:3
分类:技术文章
本文共 3709 字,大约阅读时间需要 12 分钟。
一、Deque在Java中的江湖地位
Collection是Deque的父类,所以Collection的方法Deque也可以拿来用:
Queue是Deque的父类,所以Queue的方法Deque也可以拿来用:
二、Deque自己特有的方法
Deque,双端队列之意。既然是双端队列,那么队首和队尾应该都可以:查看、添加、移除。事实上也的确如此,Deque中有大量关于头和尾的操作。
Deque的方法如下:
1、添加:addFirst、addLast、offerFirst、offerLast、push
a、代码import java.util.ArrayDeque;import java.util.Deque;public class Main { public static void main(String[] args) { Dequedeque=new ArrayDeque<>(); deque.addFirst(1); deque.addFirst(2); System.out.println("deque:"+deque); //此时队列为:[2, 1] deque.offerFirst(3); //在队首添加 System.out.println("deque:"+deque); //此时队列为:[3, 2, 1] deque.push(4); //在队首添加 System.out.println("deque:"+deque); //此时队列为:[4, 3, 2, 1] deque.offerLast(0); //在队尾添加 deque.addLast(-1); //在队尾添加 System.out.println("deque:"+deque); //此时队列为:[4, 3, 2, 1, 0, -1] }}b、结果deque:[2, 1]deque:[3, 2, 1]deque:[4, 3, 2, 1]deque:[4, 3, 2, 1, 0, -1]
2、查看:peekFirst、peekLast、getFirst、getLast
a、代码import java.util.ArrayDeque;import java.util.Arrays;import java.util.Deque;public class Main { public static void main(String[] args) { Dequedeque=new ArrayDeque<>(); deque.addAll(Arrays.asList(new Integer[]{1,2,3,4,5})); System.out.println("deque:"+deque); System.out.println("deque.peekFirst():"+deque.peekFirst()); System.out.println("deque.peekLast():"+deque.peekLast()); System.out.println("deque:"+deque); System.out.println("deque.getFirst():"+deque.getFirst()); System.out.println("deque.getLast():"+deque.getLast()); System.out.println("deque:"+deque); }}b、结果deque:[1, 2, 3, 4, 5]deque.peekFirst():1deque.peekLast():5deque:[1, 2, 3, 4, 5]deque.getFirst():1deque.getLast():5deque:[1, 2, 3, 4, 5]
区别:
import java.util.ArrayDeque;import java.util.Deque;public class Main { public static void main(String[] args) { Dequedeque=new ArrayDeque<>(); System.out.println(deque.peekFirst()); //若空返回null System.out.println(deque.peekLast()); //若空返回null //System.out.println(deque.getFirst()); //若空抛异常:NoSuchElementException //System.out.println(deque.getLast()); //若空抛异常:NoSuchElementException }}
总结:peek好,无异常!
3、移除:removeFirst、removeLast、pollFirst、pollLast、pop
a、代码import java.util.ArrayDeque;import java.util.Arrays;import java.util.Deque;public class Main { public static void main(String[] args) { Dequedeque=new ArrayDeque<>(); deque.addAll(Arrays.asList(new Integer[]{1,2,3,4,5,6,7,8})); System.out.println("deque:"+deque); System.out.println("deque.removeFirst():"+deque.removeFirst()); System.out.println("deque.removeLast():"+deque.removeLast()); System.out.println("deque:"+deque); System.out.println("deque.pollFirst():"+deque.pollFirst()); System.out.println("deque.pollLast():"+deque.pollLast()); System.out.println("deque:"+deque); System.out.println("deque.pop():"+deque.pop()); System.out.println("deque:"+deque); }}b、结果deque:[1, 2, 3, 4, 5, 6, 7, 8]deque.removeFirst():1deque.removeLast():8deque:[2, 3, 4, 5, 6, 7]deque.pollFirst():2deque.pollLast():7deque:[3, 4, 5, 6]deque.pop():3deque:[4, 5, 6]
区别:
public class Main { public static void main(String[] args) { Dequedeque=new ArrayDeque<>(); System.out.println(deque.pollFirst()); //若空返回null System.out.println(deque.pollLast()); //若空返回null System.out.println(deque.pop()); //若空抛异常:NoSuchElementException //System.out.println(deque.removeFirst()); //若空抛异常:NoSuchElementException //System.out.println(deque.removeLast()); //若空抛异常:NoSuchElementException }}
总结:poll好,无异常!
转载地址:https://liuxingchang.blog.csdn.net/article/details/109447687 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
逛到本站,mark一下
[***.202.152.39]2024年04月16日 15时27分05秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Oracle通过pivot和unpivot配合实现行列转换
2019-04-30
给Oracle数据库换一个1522端口的监听
2019-04-30
Excel表格数据生成ECharts图表
2019-04-30
阿里云短信服务python版,pyinstaller打包运行时缺少文件
2019-04-30
Oracle的pfile和spfile的一点理解和笔记
2019-04-30
WebService的简单案例记录(Java)
2019-04-30
Html利用PHP与MySQL交互
2019-04-30
dos简单命令
2019-04-30
mysql的安装与卸载与Navicat远程连接
2019-04-30
java实现稀疏数组及将稀疏数组存入硬盘中
2019-04-30
2021-05-18
2019-04-30
Flutter 使用插件打开相册、相机
2019-04-30
libuv实现tcp代理服务器
2019-04-30
libuv使用不当导致的内存泄漏
2019-04-30
libuv实现ping包发送和接收
2019-04-30
基础架构系列篇-CENTOS7安装NGINX
2019-04-30
基础架构系列篇-系统centos7安装docker+COMPOSE
2019-04-30
基础架构系列篇-系统centos7中docker安装rabbitmq
2019-04-30
基础架构系列篇-NGINX部署VUE
2019-04-30