首页 > Java > java教程 > 正文

Java中如何使用Deque的pollFirst和pollLast函数进行双端队列弹出操作

WBOY
发布: 2023-06-26 17:49:48
原创
2932人浏览过

java中deque(double ended queue,双端队列)是一种既可以在队列头部插入元素,也可以在队列尾部插入元素的数据结构。它继承自queue接口,其实现类有linkedlist和arraydeque。

Deque提供了许多弹出操作,包括pop,poll,pollFirst,pollLast,remove,removeFirst,removeLast等,这些操作都是从队列中弹出元素并且从队列中移除该元素。本文将着重介绍Deque中的pollFirst和pollLast函数的使用。

pollFirst方法弹出并且返回双端队列的第一个元素,如果队列为空,返回null。下面是pollFirst方法的声明:

E pollFirst();
登录后复制

其中,E表示双端队列中的元素类型。

pollLast方法弹出并且返回双端队列的最后一个元素,如果队列为空,返回null。下面是pollLast方法的声明:

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

E pollLast();
登录后复制

下面的示例展示了如何使用Deque的pollFirst和pollLast函数进行双端队列弹出操作:

import java.util.*;

public class DequeExample {
    public static void main(String[] args) {
        Deque<Integer> deque = new LinkedList<Integer>();
        
        deque.addFirst(1); //在队列头部插入元素
        deque.addFirst(2);
        deque.addLast(3); //在队列尾部插入元素
        deque.addLast(4);
        
        System.out.println(deque); // 输出 [2, 1, 3, 4]
        
        Integer firstElement = deque.pollFirst(); // 弹出队列头部的元素
        System.out.println("弹出的队列头部元素为: " + firstElement); // 输出 2
        System.out.println(deque); // 输出 [1, 3, 4]
        
        Integer lastElement = deque.pollLast(); // 弹出队列尾部的元素
        System.out.println("弹出的队列尾部元素为: " + lastElement); // 输出 4
        System.out.println(deque); // 输出 [1, 3]
    }
}
登录后复制

上述示例中,我们首先创建了一个双端队列LinkedList,然后使用addFirst和addLast函数向队列中插入元素,接着使用pollFirst和pollLast函数弹出队列头部和尾部的元素。最后,我们打印出每个步骤后Deque中的元素。

总之,Deque类是Java中非常有用的数据结构,它提供了许多功能,包括队列的弹出操作。其中,pollFirst和pollLast函数可以帮助我们轻松地弹出队列头部和尾部的元素,并且Deque中的元素可以在任意一段进行插入和删除。这些特性使Deque变得非常适用于一些场景,例如LRU Cache等。

以上就是Java中如何使用Deque的pollFirst和pollLast函数进行双端队列弹出操作的详细内容,更多请关注php中文网其它相关文章!

相关标签:
java速学教程(入门到精通)
java速学教程(入门到精通)

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

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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