IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> java36-集合进阶-Queue集合-特有方法-LinkedList-PriorityQueue -> 正文阅读

[数据结构与算法]java36-集合进阶-Queue集合-特有方法-LinkedList-PriorityQueue

Queue集合

Queue集合继承自Collection接口,它的常用实现类是LinkedList 和 PriorityQueue 类。
Queue用来存放等待处理元素的集合,这种场景一般用来缓冲、并发访问。

Queue特有方法

方法名说明
添加操作
Boolean add(E e)
Boolean offer(E e )
在尾部添加,实现类禁止添加null元素
添加失败,会报运行时错误NullPointerException
添加失败,不会崩溃,返回false
删除操作
E remove()
E poll()
删除头部并返回头部
队列为空,报NoSuchElementException错
队列为空,返回null
查询操作
E element()
E peek()
获取但不删除
队列为空,报错
队列为空,返回null
判断是否含有某元素
Boolean contain(E e)
判断队列中是否包含某个元素

注意:

  • 大多数实现Queue接口的实现类都具有禁止添加null元素的功能,避免在查询时返回null,比如ArrayBlockingQueue,PriorityBlockQueue;但是还有一些实现类没有实现这样的功能,比如LinkedList。
  • 虽然LinkedList没有明确禁止添加null元素,但是Queue的实现都类不允许添加null元素,原因是:poll、peek方法在异常(对队列为空)的时候会返回null,当添加null元素后,会产生歧义(不知道是发生异常还是获取到null元素)

LinkedList

概述

  • LinkedList类是双向链表,列表中的每个节点都包含一个对前一个和后一个元素的引用。
  • LinkedList可以被当作堆栈、队列或者双端队列进行操作。
  • LinkedList实现了Serializable接口,所以可以被序列化,能通过序列化去传输。
  • LinkedList是非同步的。
  • LinkedList本质是双向链表,包含两个重要成员:header 和 size 。
    • header是双向链表的表头,它是双向链表节点所对应的类Entry的实例。Entry中包含成员变量:previous、next、element。其中previous是该节点的上一个,next是该节点的下一个,element是该节点所包含的值。
    • size是双向链表中节点的个数。

构造函数

函数说明
LinkedList()默认构造函数
LinkedList(Collection<? extends E > collection)创建一个LinkedList,保护Collection中的全部元素

常用方法

方法名说明
public void addFirst(E e)在列表的首部添加一个元素
public void addLast(E e)在列表的尾部添加一个元素
public E removeFirst()在列表的首部删除一个元素并返回
public E removeLast()在列表的尾部删除一个元素并返回
public E getFirst()在列表的首部获取一个元素并返回
public E getLast()在列表的尾部获取一个元素并返回

PriorityQueue

概念

队列的核心思想是先进先出,优先级队列有点不一样。
优先级队列中,数据按关键词有序排列,插入新数据的时候,会自动插入到合适的位置保证队列的有序性。(有序:升序或降序)
PriorityQueue是基于优先堆的一个无界队列,队列中的元素排序:默认的自然排序(使用Comparable接口)或比较器排序(使用Comparator接口)。

方法

都是Queue中的方法。add、offer、remove、poll、get、element、peek。
具体方法讲解

  • 添加元素 add()/offer()
        System.out.println(que.add(null));
        // 添加null元素,会报NullPointerException
        System.out.println(que.offer(null));
        // 添加null元素,则会报NullPointerException
        System.out.println(que.add(100));
        System.out.println(que.add(10));
        System.out.println(que.add(30));
        System.out.println(que.add(20));
        System.out.println(que);//输出[10, 20,30,100]
  • 获取元素 element()/peek()
        System.out.println(que.element());//10
        System.out.println(que.peek());//10
        // 获取元素 默认情况下 每次获取的元素是列表头部元素
        System.out.println(que);//[10, 20, 30, 100]
  • 删除元素 remove()/poll()
 System.out.println(que.remove());//10
        System.out.println(que.poll());//20
        // 依次删除头部元素
        System.out.println(que);//[30, 100]
  • 判断元素是否存在 contain(E e)
System.out.println(que.contains(30));//true
  • 整体代码:
public class QueueDEmo {
    public static void main(String[] args) {
        Queue<Integer> que = new PriorityQueue<Integer>();

//        System.out.println(que.add(null));
        // 添加null元素,会报NullPointerException
//        System.out.println(que.offer(null));
        // 添加null元素,则会报NullPointerException
        System.out.println(que.add(100));
        System.out.println(que.add(10));
        System.out.println(que.add(30));
        System.out.println(que.add(20));
        System.out.println(que);//输出[10, 20,30,100]

        System.out.println("------------");
        System.out.println(que.element());//10
        System.out.println(que.peek());//10
        // 获取元素 默认情况下 每次获取的元素是列表头部元素
        System.out.println(que);

        System.out.println("----------");
        System.out.println(que.remove());//10
        System.out.println(que.poll());//20
        // 依次删除头部元素
        System.out.println(que);//30 ,100


    }
}
案例

案例1
需求:在未排序的数组中,找到第K个未排序的最大值。
解题思路:

思路1:冒泡排序
外层循环控制比较的轮次,for(int i =0;i<array.length;i++)
	内存循环控制每轮比较次数 for(int j = i ;j<array.length;j++)
	当i++ == k的时候退出循环。
思路2Queue优先级队列实现
方法传入参数int[] array,int k
	创建PriorityQueue队列
	使用增强for循环(数据类型 变量名:数组名)
		使用队列.add(变量名),给队列添加元素
	判断队列元素>k,则删除队列元素 队列.poll()
	最后返回值是 队列.peek()

代码:冒泡排序

// 330-Test1
public class Test1 {
    // 需求:在未排序的数组中,找到第K个未排序的最大值。
    public static int findKthLargest(int[] array, int K){
        int result = array[0];
        int tep = 0;
        // 使用冒泡排序
        // 外层循环表示程序 比较轮数
        for(int i = 0;i <array.length;i++){
            // 内层循环表示 每轮比较次数
            for(int j = i+1; j<array.length;j++ ){
                if(array[i] > array[j]){
                    tep = array[i];
                    array[i] = array[j];
                    array[j] = tep;
                }
            }
            if(i++ == K){
                result = array[array.length-K];
                break;
            }
        }
        return result;
    }

    public static void main(String[] args) {
        int[] array = {10,9,5,24,35};
        int result = findKthLargest(array,3);
        System.out.println(result);
    }
}

代码:优先级队列PriorityQueue

    // 优先级队列实现
    public static int findKthLargestQueue(int[] array,int k){
        Queue<Integer> que = new PriorityQueue<Integer>();
        for(int arr:array){
            que.add(arr);
            if(que.size() > k) que.poll();
        }
        return que.peek();
    }
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 00:19:45  更:2022-04-01 00:22:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:17:42-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码