亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java中的PriorityQueue類過程詳解

 更新時(shí)間:2021年09月06日 10:13:10   作者:是木子啦~  
這篇文章主要介紹了java中的PriorityQueue類,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、什么是優(yōu)先級(jí)隊(duì)列

1、概念

我們都知道隊(duì)列,隊(duì)列的核心思想就是先進(jìn)先出,這個(gè)優(yōu)先級(jí)隊(duì)列有點(diǎn)不太一樣。優(yōu)先級(jí)隊(duì)列中,數(shù)據(jù)按關(guān)鍵詞有序排列,插入新數(shù)據(jù)的時(shí)候,會(huì)自動(dòng)插入到合適的位置保證隊(duì)列有序。(順序有兩種形式:升序或者是降序)

來一個(gè)標(biāo)準(zhǔn)點(diǎn)的定義:

PriorityQueue類在Java1.5中引入。PriorityQueue是基于優(yōu)先堆的一個(gè)無界隊(duì)列,這個(gè)優(yōu)先隊(duì)列中的元素可以默認(rèn)自然排序或者通過提供的Comparator(比較器)在隊(duì)列實(shí)例化的時(shí)排序。要求使用Java Comparable和Comparator接口給對(duì)象排序,并且在排序時(shí)會(huì)按照優(yōu)先級(jí)處理其中的元素。

比如我們往隊(duì)列里面插入132,插入2的時(shí)候,就會(huì)在內(nèi)部調(diào)整為123(默認(rèn)順序是升序)。正是由于這個(gè)優(yōu)良特性可以幫助我們實(shí)現(xiàn)一系列問題。我們先看一個(gè)例子,體會(huì)一下他的優(yōu)點(diǎn),然后再看一下為什么能夠?qū)崿F(xiàn)這樣的功能。

在這里插入圖片描述

我們看到就算是我們隨意插入數(shù)據(jù),但是輸出的結(jié)果總是有序的,這樣一來優(yōu)先級(jí)隊(duì)列就可以有了很多個(gè)使用場景。下面給出一道力扣題。體會(huì)一下他的優(yōu)點(diǎn)。

2、案例演示特性

Leetcode215題:在未排序的數(shù)組中找到第 k個(gè)最大的元素。請(qǐng)注意,你需要找的是數(shù)組排序后的第 k 個(gè)最大的元素,而不是第 k 個(gè)不同的元素。

輸入:3,2,3,1,2,4,5,5,6,k = 4。輸出就是5,因此重復(fù)的并不考慮。我們一般情況下一般首先想到冒泡排序。每一次都冒出來一個(gè)最小的元素,這樣冒K次,就是我們想要的結(jié)果。

在這里插入圖片描述

其實(shí)冒泡排序還可以解決另外一個(gè)問題,那就是返回倒數(shù)第K大的元素,方法是每次冒出來一個(gè)最大的元素即可。

這樣做很簡單,但是需要我們自己手寫冒泡排序,下面我們看使用優(yōu)先級(jí)隊(duì)列如何解決的。

在這里插入圖片描述

就這幾行代碼就搞定了,是不是超級(jí)簡單。為什么優(yōu)先級(jí)隊(duì)列能夠?qū)崿F(xiàn)呢?下面我們來分析一下他的數(shù)據(jù)結(jié)構(gòu):

3、數(shù)據(jù)結(jié)構(gòu)

優(yōu)先級(jí)隊(duì)列底層的數(shù)據(jù)結(jié)構(gòu)其實(shí)是一顆二叉堆,什么是二叉堆呢?我們來看看

在這里插入圖片描述

在這里我們會(huì)發(fā)現(xiàn)以下特征:

(1)二叉堆是一個(gè)完全二叉樹

(2)根節(jié)點(diǎn)總是大于左右子節(jié)點(diǎn)(大頂堆),或者是小于左右子節(jié)點(diǎn)(小頂堆)。

如果我們要插入一個(gè)節(jié)點(diǎn)怎么辦呢?

在這里插入圖片描述

自己使用畫圖工具畫的,能看懂就行,不要在意那些細(xì)節(jié)兄弟。過程如下:

(1)找到待插入位置:滿足完全二叉樹的特點(diǎn),依次插入

(2)插入之后判斷是否滿足二叉堆的性質(zhì),不滿足那就調(diào)整

(3)1<>6交換,發(fā)現(xiàn)不滿足,1<>4交換,滿足即停止。

對(duì)于我們的優(yōu)先級(jí)隊(duì)列就是這樣的一種數(shù)據(jù)結(jié)構(gòu),因此我們在插入的時(shí)候保證了數(shù)據(jù)的有序性。

OK。到這基本上我們能夠體會(huì)到優(yōu)先級(jí)隊(duì)列的思想了。來一個(gè)小結(jié):

優(yōu)先級(jí)隊(duì)列使用二叉堆的特點(diǎn),可以使得插入的數(shù)據(jù)自動(dòng)排序(升序或者是降序)。

到此這篇關(guān)于java中的PriorityQueue類的文章就介紹到這了,更多相關(guān)java PriorityQueue類內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Mybatis批量刪除數(shù)據(jù)操作方法

    Mybatis批量刪除數(shù)據(jù)操作方法

    MyBatis的作用我想不用多說,今天說說MyBatis中的批量刪除操作。 非常不錯(cuò),感興趣的朋友一起看看吧
    2016-09-09
  • SpringBoot超詳細(xì)講解yaml配置文件

    SpringBoot超詳細(xì)講解yaml配置文件

    這篇文章主要介紹了SpringBoot中的yaml配置文件問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • Java 實(shí)戰(zhàn)項(xiàng)目之小說在線閱讀系統(tǒng)的實(shí)現(xiàn)流程

    Java 實(shí)戰(zhàn)項(xiàng)目之小說在線閱讀系統(tǒng)的實(shí)現(xiàn)流程

    讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實(shí)現(xiàn)前臺(tái)閱讀后臺(tái)管理的小說在線閱讀系統(tǒng),大家可以在過程中查缺補(bǔ)漏,提升水平
    2021-11-11
  • Java 高并發(fā)八:NIO和AIO詳解

    Java 高并發(fā)八:NIO和AIO詳解

    本文主要介紹Java 高并發(fā)NIO和AIO 的知識(shí),這里整理了詳細(xì)的資料,并詳細(xì)介紹了 1. 什么是NIO 2. Buffer 3. Channel 4. 網(wǎng)絡(luò)編程 5. AIO的知識(shí),有需要的小伙伴可以參考下
    2016-09-09
  • Response.AddHeader案例講解

    Response.AddHeader案例講解

    這篇文章主要介紹了Response.AddHeader案例講解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 詳解Spring Retry實(shí)現(xiàn)原理

    詳解Spring Retry實(shí)現(xiàn)原理

    這篇文章主要介紹了詳解Spring Retry實(shí)現(xiàn)原理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • Java 實(shí)戰(zhàn)練習(xí)之網(wǎng)上電商項(xiàng)目的實(shí)現(xiàn)

    Java 實(shí)戰(zhàn)練習(xí)之網(wǎng)上電商項(xiàng)目的實(shí)現(xiàn)

    讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+vue+Springboot+ssm+mysql+maven+redis實(shí)現(xiàn)一個(gè)網(wǎng)上電商項(xiàng)目,大家可以在過程中查缺補(bǔ)漏,提升水平
    2021-11-11
  • 深入探究Java?@MapperScan實(shí)現(xiàn)原理

    深入探究Java?@MapperScan實(shí)現(xiàn)原理

    之前是直接在Mapper類上面添加注解@Mapper,這種方式要求每一個(gè)mapper類都需要添加此注解,麻煩。通過使用@MapperScan可以指定要掃描的Mapper類的包的路徑,這篇文章深入探究Java?@MapperScan的實(shí)現(xiàn)原理
    2023-01-01
  • 淺析java 希爾排序(Shell)算法

    淺析java 希爾排序(Shell)算法

    這篇文章主要介紹了淺析java 希爾排序(Shell)算法的原理以及示例,需要的朋友可以參考下
    2015-02-02
  • Spring循環(huán)引用失敗問題源碼解析

    Spring循環(huán)引用失敗問題源碼解析

    這篇文章主要為大家介紹了Spring循環(huán)引用失敗問題源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09

最新評(píng)論