国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立

這篇具有很好參考價(jià)值的文章主要介紹了【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

??優(yōu)先級(jí)隊(duì)列

【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java

?????優(yōu)先級(jí)隊(duì)列的概念

前面介紹過隊(duì)列,隊(duì)列是一種先進(jìn)先出(FIFO)的數(shù)據(jù)結(jié)構(gòu),但有些情況下,操作的數(shù)據(jù)可能帶有優(yōu)先級(jí),一般出隊(duì)列時(shí),可能需要優(yōu)先級(jí)高的元素先出隊(duì)列,該中場(chǎng)景下,使用隊(duì)列顯然不合適。

比如:在手機(jī)上玩游戲的時(shí)候,如果有來電,那么系統(tǒng)應(yīng)該優(yōu)先處理打進(jìn)來的電話;初中那會(huì)班主任排座位時(shí)可能會(huì)讓成績好的同學(xué)先挑座位。

在這種情況下,數(shù)據(jù)結(jié)構(gòu)應(yīng)該提供兩個(gè)最基本的操作,一個(gè)是返回最高優(yōu)先級(jí)對(duì)象,一個(gè)是添加新的對(duì)象。這種數(shù)據(jù)結(jié)構(gòu)就是優(yōu)先級(jí)隊(duì)列(Priority Queue)。

??堆的由來

為了模擬實(shí)現(xiàn)優(yōu)先級(jí)隊(duì)列的模擬實(shí)現(xiàn),JDK1.8中的PriorityQueue底層使用了堆這種數(shù)據(jù)結(jié)構(gòu),而堆實(shí)際就是在完全二叉樹的基礎(chǔ)上進(jìn)行了一些調(diào)整。

?????堆的概念

如果有一個(gè)關(guān)鍵碼的集合K = {k0,k1, k2,…,kn-1},把它的所有元素按完全二叉樹的順序存儲(chǔ)方式存儲(chǔ) 在一個(gè)一維數(shù)組中,并滿足:Ki <= K2i+1 且 Ki<= K2i+2 (Ki >= K2i+1 且 Ki >= K2i+2) i = 0,1,2…,則稱為 小堆(或大
堆)。
將根節(jié)點(diǎn)最大的堆叫做最大堆或大根堆,根節(jié)點(diǎn)最小的堆叫做最小堆或小根堆

?????堆的性質(zhì)

  • 堆中某個(gè)節(jié)點(diǎn)的值總是不大于或不小于其父節(jié)點(diǎn)的值;

  • 堆總是一棵完全二叉樹。

【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java

?????堆的存儲(chǔ)方式

從堆的概念可知,堆是一棵完全二叉樹,因此可以層序的規(guī)則采用順序的方式來高效存儲(chǔ)

【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java
注意:對(duì)于非完全二叉樹,則不適合使用順序方式進(jìn)行存儲(chǔ),因?yàn)闉榱四軌蜻€原二叉樹,空間中必須要存儲(chǔ)空節(jié)點(diǎn),就會(huì)導(dǎo)致空間利用率比較低

將元素存儲(chǔ)到數(shù)組中后,可以根據(jù)二叉樹章節(jié)的性質(zhì)5對(duì)樹進(jìn)行還原。假設(shè)i為節(jié)點(diǎn)在數(shù)組中的下標(biāo),則有:

  • 如果i為0,則i表示的節(jié)點(diǎn)為根節(jié)點(diǎn),否則i節(jié)點(diǎn)的雙親節(jié)點(diǎn)為 (i - 1)/2

  • 如果2 * i + 1 小于節(jié)點(diǎn)個(gè)數(shù),則節(jié)點(diǎn)i的左孩子下標(biāo)為2 * i + 1,否則沒有左孩子

  • 如果2 * i + 2 小于節(jié)點(diǎn)個(gè)數(shù),則節(jié)點(diǎn)i的右孩子下標(biāo)為2 * i + 2,否則沒有右孩子

??堆的創(chuàng)建

?????堆向下調(diào)整

對(duì)于集合{ 27,15,19,18,28,34,65,49,25,37 }中的數(shù)據(jù),如果將其創(chuàng)建成堆呢?
【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java

仔細(xì)觀察上圖后發(fā)現(xiàn):根節(jié)點(diǎn)的左右子樹已經(jīng)完全滿足堆的性質(zhì),因此只需將根節(jié)點(diǎn)向下調(diào)整好即可。

向下過程(以小堆為例):

  1. 讓parent標(biāo)記需要調(diào)整的節(jié)點(diǎn),child標(biāo)記parent的左孩子(注意:parent如果有孩子一定先是有左孩子)
  2. 如果parent的左孩子存在,即:child < size, 進(jìn)行以下操作,直到parent的左孩子不存在

parent右孩子是否存在,存在找到左右孩子中最小的孩子,讓child進(jìn)行標(biāo)
將parent與較小的孩子child比較,如果

  • parent小于較小的孩子child,調(diào)整結(jié)束
  • 否則:交換parent與較小的孩子child,交換完成之后,parent中大的元素向下移動(dòng),可能導(dǎo)致子樹不滿足對(duì)的性質(zhì),因此需要繼續(xù)向下調(diào)整
    即parent = child;child = parent*2+1; 然后繼續(xù)2。

【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java
大堆實(shí)現(xiàn)與其類似

?????代碼實(shí)現(xiàn)

public class MyHeap {
    public void shiftDown(int[] array, int parent) {
        // child先標(biāo)記parent的左孩子,因?yàn)閜arent可能右左沒有右
        int child = 2*parent + 1;
        int size = array.length;
        while(child < size ) {
            // 如果右孩子存在,找到左右孩子中較小的孩子,用child進(jìn)行標(biāo)記
            if(child + 1 < size) {
                if(array[child + 1] < array[child]) {
                    child = child + 1;
                }
            }
            // 如果最小的孩子比其父親還小,說明該結(jié)構(gòu)沒有滿足堆的特性,進(jìn)行交換
            if(array[child] < array[parent]) {
                int tmp = array[parent];
                array[parent] = array[child];
                array[child] = tmp;
            } else {
                //滿足就退出循環(huán)
                break;
            }
            // parent中大的元素往下移動(dòng),可能會(huì)造成子樹不滿足堆的性質(zhì),因此需要繼續(xù)向下調(diào)整
            parent = child;
            child = 2*parent + 1;
        }
    }
}

??代碼測(cè)試結(jié)果展示

測(cè)試代碼

public class TestMain {
    public static void main(String[] args) {
        MyHeap myHeap = new MyHeap();
        int[] array = {27,15,19,18,28,34,65,49,25,37};
        System.out.println("調(diào)整前:");
        for(int i = 0; i < array.length ; i++) {
            System.out.print(array[i] + " ");
        }
        for(int parent = (array.length-2)/2 ; parent >= 0; parent --) {
            myHeap.shiftDown(array, parent);
        }
        System.out.println();
        System.out.println("調(diào)整后:");
        for(int i = 0; i < array.length ; i++) {
            System.out.print(array[i] + " ");
        }
        System.out.println();
    }
}

測(cè)試結(jié)果
【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java

注意:在調(diào)整以parent為根的二叉樹時(shí),必須要滿足parent的左子樹和右子樹已經(jīng)是堆了才可以向下調(diào)整。

時(shí)間復(fù)雜度分析:

最壞的情況即圖示的情況,從根一路比較到葉子,比較的次數(shù)為完全二叉樹的高度,即時(shí)間復(fù)雜度為
【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java

??建堆的時(shí)間復(fù)雜度

對(duì)于普通的序列{ 1,5,3,8,7,6 },我們需要建立大堆,即根節(jié)點(diǎn)的左右子樹不滿足堆的特性,又該如何調(diào)整呢?
【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java
做法如下:

找倒數(shù)第一個(gè)非葉子節(jié)點(diǎn),從該節(jié)點(diǎn)位置開始往前一直到根節(jié)點(diǎn),遇到一個(gè)節(jié)點(diǎn),應(yīng)用向下調(diào)整

for(int parent = (array.length-2)/2 ; parent >= 0; parent --) {
	myHeap.bigDown(array, parent);
}

那么時(shí)間復(fù)雜度又為多少呢?

因?yàn)槎咽峭耆鏄?,而滿二叉樹也是完全二叉樹,此處為了簡化使用滿二叉樹來證明(時(shí)間復(fù)雜度本來看的就是近似值,多幾個(gè)節(jié)點(diǎn)不影響最終結(jié)果):

【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立,數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),優(yōu)先級(jí)隊(duì)列,堆,java
因此:建堆的時(shí)間復(fù)雜度為O(N)

?總結(jié)

關(guān)于《【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立》就講解到這兒,感謝大家的支持,歡迎各位留言交流以及批評(píng)指正,如果文章對(duì)您有幫助或者覺得作者寫的還不錯(cuò)可以點(diǎn)一下關(guān)注,點(diǎn)贊,收藏支持一下!文章來源地址http://www.zghlxwxcb.cn/news/detail-695170.html

到了這里,關(guān)于【數(shù)據(jù)結(jié)構(gòu)】 優(yōu)先級(jí)隊(duì)列(堆)與堆的建立的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 數(shù)據(jù)結(jié)構(gòu)與算法-優(yōu)先級(jí)隊(duì)列

    Gitee上開源的數(shù)據(jù)結(jié)構(gòu)與算法代碼庫:數(shù)據(jù)結(jié)構(gòu)與算法Gitee代碼庫 優(yōu)先級(jí)隊(duì)列,按照優(yōu)先級(jí)別依次輸出 計(jì)算機(jī)科學(xué)中,堆是一種基于樹的數(shù)據(jù)結(jié)構(gòu),通常用 完全二叉樹 實(shí)現(xiàn)。堆的特性如下 在大頂堆中,任意節(jié)點(diǎn) C 與它的父節(jié)點(diǎn) P 符合 P . v a l u e ≥ C . v a l u e P.value geq C.val

    2024年02月13日
    瀏覽(36)
  • 數(shù)據(jù)結(jié)構(gòu) 之 優(yōu)先級(jí)隊(duì)列(堆) (PriorityQueue)

    數(shù)據(jù)結(jié)構(gòu) 之 優(yōu)先級(jí)隊(duì)列(堆) (PriorityQueue)

    ??歡迎大家觀看AUGENSTERN_dc的文章(o゜▽゜)o☆?? ??感謝各位讀者在百忙之中抽出時(shí)間來垂閱我的文章,我會(huì)盡我所能向的大家分享我的知識(shí)和經(jīng)驗(yàn)?? ??希望我們?cè)谝黄奈恼轮心軌蚬餐M(jìn)步!?。???個(gè)人主頁:AUGENSTERN_dc ??個(gè)人專欄:C語言?|?Java | 數(shù)據(jù)結(jié)構(gòu) ?個(gè)人

    2024年03月20日
    瀏覽(27)
  • 數(shù)據(jù)結(jié)構(gòu)之優(yōu)先級(jí)隊(duì)列【堆】(Heap)

    數(shù)據(jù)結(jié)構(gòu)之優(yōu)先級(jí)隊(duì)列【堆】(Heap)

    目錄 1. 優(yōu)先級(jí)隊(duì)列(Priority Queue) 2.堆的概念 3.堆的存儲(chǔ)方式 4.堆的創(chuàng)建 5.用堆模擬實(shí)現(xiàn)優(yōu)先級(jí)隊(duì)列 ?6.PriorityQueue常用接口介紹 6.1?PriorityQueue的特點(diǎn) 6.2?PriorityQueue幾種常見的構(gòu)造方式 7.top-k問題 8.堆排序 本篇主要內(nèi)容總結(jié) (1)優(yōu)先級(jí)隊(duì)列底層是堆來實(shí)現(xiàn)的 (2)堆的本質(zhì)是

    2024年02月01日
    瀏覽(51)
  • 【一起學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)與算法】優(yōu)先級(jí)隊(duì)列(堆)

    【一起學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)與算法】優(yōu)先級(jí)隊(duì)列(堆)

    如果我們給每個(gè)元素都分配一個(gè)數(shù)字來標(biāo)記其優(yōu)先級(jí),不妨設(shè)較小的數(shù)字具有較高的優(yōu)先級(jí),這樣我們就可以在一個(gè)集合中訪問優(yōu)先級(jí)最高的元素并對(duì)其進(jìn)行查找和刪除操作了。這樣,我們就引入了 優(yōu)先級(jí)隊(duì)列 這種數(shù)據(jù)結(jié)構(gòu)。 優(yōu)先級(jí)隊(duì)列(priority queue) 是0個(gè)或多個(gè)元素的集

    2024年01月19日
    瀏覽(24)
  • 數(shù)據(jù)結(jié)構(gòu) - 6(優(yōu)先級(jí)隊(duì)列(堆)13000字詳解)

    數(shù)據(jù)結(jié)構(gòu) - 6(優(yōu)先級(jí)隊(duì)列(堆)13000字詳解)

    堆分為兩種:大堆和小堆。它們之間的區(qū)別在于元素在堆中的排列順序和訪問方式。 大堆(Max Heap): 在大堆中,父節(jié)點(diǎn)的值比它的子節(jié)點(diǎn)的值要大。也就是說,堆的根節(jié)點(diǎn)是堆中最大的元素。大堆被用于實(shí)現(xiàn)優(yōu)先級(jí)隊(duì)列,其中根節(jié)點(diǎn)的元素始終是隊(duì)列中最大的元素。 大堆

    2024年02月08日
    瀏覽(25)
  • 【數(shù)據(jù)結(jié)構(gòu)與算法】03 隊(duì)列(順序隊(duì)列--循環(huán)隊(duì)列--優(yōu)先級(jí)隊(duì)列--鏈隊(duì)列)

    【數(shù)據(jù)結(jié)構(gòu)與算法】03 隊(duì)列(順序隊(duì)列--循環(huán)隊(duì)列--優(yōu)先級(jí)隊(duì)列--鏈隊(duì)列)

    隊(duì)列( queue )是一種常見的數(shù)據(jù)結(jié)構(gòu),它遵循先進(jìn)先出(FIFO)的原則。隊(duì)列可以理解為一個(gè)具有兩個(gè)端點(diǎn)的線性數(shù)據(jù)結(jié)構(gòu),其中一個(gè)端點(diǎn)稱為\\\"隊(duì)尾\\\"(rear),用于插入新元素,另一個(gè)端點(diǎn)稱為\\\"隊(duì)首\\\"(front),用于移除元素。新元素被插入到隊(duì)尾,而最早插入的元素總是在隊(duì)

    2024年02月08日
    瀏覽(21)
  • Java 數(shù)據(jù)結(jié)構(gòu)篇-用數(shù)組、堆實(shí)現(xiàn)優(yōu)先級(jí)隊(duì)列

    Java 數(shù)據(jù)結(jié)構(gòu)篇-用數(shù)組、堆實(shí)現(xiàn)優(yōu)先級(jí)隊(duì)列

    ??博客主頁:?【 小扳_-CSDN博客】 ?感謝大家點(diǎn)贊??收藏?評(píng)論? ?? 文章目錄 ? ? ? ? 1.0 優(yōu)先級(jí)隊(duì)列說明 ? ? ? ? 2.0 用數(shù)組實(shí)現(xiàn)優(yōu)先級(jí)隊(duì)列 ? ? ? ? 3.0?無序數(shù)組實(shí)現(xiàn)優(yōu)先級(jí)隊(duì)列 ? ? ? ? 3.1 無序數(shù)組實(shí)現(xiàn)優(yōu)先級(jí)隊(duì)列 - 入隊(duì)列 offer(E value) ? ? ? ? 3.2 無序數(shù)組實(shí)現(xiàn)優(yōu)先

    2024年02月04日
    瀏覽(22)
  • 【數(shù)據(jù)結(jié)構(gòu)初階】——第八節(jié).優(yōu)先級(jí)隊(duì)列(小根堆的模擬實(shí)現(xiàn))

    【數(shù)據(jù)結(jié)構(gòu)初階】——第八節(jié).優(yōu)先級(jí)隊(duì)列(小根堆的模擬實(shí)現(xiàn))

    ?作者簡介:大家好,我是未央; 博客首頁: 未央.303 系列專欄:Java初階數(shù)據(jù)結(jié)構(gòu) 每日一句:人的一生,可以有所作為的時(shí)機(jī)只有一次,那就是現(xiàn)在?。。?目錄 文章目錄 前言 引言 一、堆的概念 二、堆的性質(zhì)? 三、堆的操作 3.1 向下調(diào)整算法 3.2?小根堆的創(chuàng)建 3.3?向上調(diào)整

    2024年02月07日
    瀏覽(31)
  • 經(jīng)典TopK問題、優(yōu)先級(jí)隊(duì)列 與 堆的糾葛一文為你解惑——數(shù)據(jù)結(jié)構(gòu)

    經(jīng)典TopK問題、優(yōu)先級(jí)隊(duì)列 與 堆的糾葛一文為你解惑——數(shù)據(jù)結(jié)構(gòu)

    前言: 本篇文章以 TopK 問題為引,具體闡述了 PriorityQueue 實(shí)現(xiàn)的基本邏輯——堆 數(shù)據(jù)結(jié)構(gòu),以及PriorityQueue 的常用方法。如有問題歡迎看官朋友指正,如果覺得文章還不錯(cuò)的話,求點(diǎn)贊、收藏、評(píng)論 三連。 重點(diǎn): 堆的基本實(shí)現(xiàn)邏輯 PriorityQueue 運(yùn)用和源碼分析 TopK 問題的解法

    2023年04月22日
    瀏覽(18)
  • 【堆的認(rèn)識(shí)及其優(yōu)先級(jí)隊(duì)列】java代碼實(shí)現(xiàn),保姆級(jí)教程學(xué)習(xí)堆和優(yōu)先級(jí)隊(duì)列

    【堆的認(rèn)識(shí)及其優(yōu)先級(jí)隊(duì)列】java代碼實(shí)現(xiàn),保姆級(jí)教程學(xué)習(xí)堆和優(yōu)先級(jí)隊(duì)列

    前言: 大家好,我是 良辰 丫?????,我們又見面了,前面我們講了用鏈表實(shí)現(xiàn)的二叉樹,今天我們來接觸 堆 的概念,堆是一種特殊的二叉樹,只不過咱們的對(duì)底層原理是數(shù)組,堆也是我們?cè)谧鲱}中經(jīng)常見到的,那么,接下來我們就慢慢的去接觸堆, 認(rèn)識(shí)堆,理解堆,掌

    2024年02月02日
    瀏覽(32)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包