構(gòu)建最大堆(數(shù)組化表示)與堆排序

1. 最大堆的數(shù)組化表示

假設(shè)有一個(gè)數(shù)組 int[] arr = {8,9,10,11,12,13,14};
用它來(lái)構(gòu)建最大堆

2. 基本思路

  1. 最大堆或最小堆都是完全二叉樹(shù),利用這個(gè)性質(zhì)琅翻,先按照數(shù)組順序構(gòu)建最簡(jiǎn)單的完全二叉樹(shù)
  2. 從最后一個(gè)節(jié)點(diǎn)的父節(jié)點(diǎn)(arr.length / 2 - 1)開(kāi)始 逐次調(diào)整位置屁奏,開(kāi)始構(gòu)建最大堆
    2.1 若父節(jié)點(diǎn)小于左節(jié)點(diǎn)供填,父節(jié)點(diǎn)與左節(jié)點(diǎn)互換驶忌,繼續(xù)調(diào)整
    2.2 若父節(jié)點(diǎn)小于右節(jié)點(diǎn)伟姐,父節(jié)點(diǎn)與右節(jié)點(diǎn)互換(注意是經(jīng)過(guò)2.1)豹芯,繼續(xù)調(diào)整

3. 構(gòu)建示意圖

image.png

4. 源代碼

static int[] arr = {8, 9, 10, 11, 12, 13, 14};

    public static void main(String[] args) {
        /*
         * 調(diào)用建立大頂堆方法:
         * index:傳入最后一個(gè)非葉子節(jié)點(diǎn)罚拟,即list.size()/2-1;
         * */

        for (int i = arr.length / 2 - 1; i >= 0; i--) {
            buildHeap(arr, i, arr.length);
        }
        System.out.println("輸出最大堆:");
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println();
        System.out.println("升序排列結(jié)果:");
        heapSort(arr);
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
    public static void buildHeap(int[] arr, int index, int size) {
        int leftchild = 2 * index + 1;
        int rightchild = 2 * index + 2;
        int temp = index;
        if (leftchild < size && arr[index] < arr[leftchild]) {
            index = leftchild;
        }
        if (rightchild < size && arr[index] < arr[rightchild]) {
            index = rightchild;
        }
        if (index != temp) {
            swap(arr, temp, index);
            // 交換后繼續(xù)向下調(diào)整,以index為父節(jié)點(diǎn)台诗,繼續(xù)向下調(diào)整
            buildHeap(arr, index, size);
        }
    }

    /*
     * 堆排序:
     *      1)將已經(jīng)建立好的大頂堆,每次取出根節(jié)點(diǎn)赐俗,即最大值拉队。
     *      2)將最后一個(gè)節(jié)點(diǎn)的值賦給根節(jié)點(diǎn),重新構(gòu)建大頂堆阻逮。
     *      3)刪除最后節(jié)點(diǎn)的數(shù)據(jù)
     * */
    public static void heapSort(int[] arr) {
        for (int i = arr.length - 1; i >= 0; i--) {
            swap(arr, i, 0);
            // 從根節(jié)點(diǎn)向下調(diào)整粱快,每次取出一個(gè)數(shù)值,集合長(zhǎng)度逐漸減小
            buildHeap(arr, 0, i);
        }
    }

    public static void swap(int[] a, int i, int j) {
        int temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }

5 堆排序

基本思路
1)將已經(jīng)建立好的大頂堆叔扼,每次取根節(jié)點(diǎn)事哭,即最大值,并與最后的節(jié)點(diǎn)交換瓜富。
2)重新構(gòu)建大頂堆鳍咱,注意索引是從int i = arr.length - 1 開(kāi)始的,重建大頂堆時(shí)与柑,實(shí)際上相當(dāng)于刪除了最后一個(gè)元素谤辜,即刪除了剛剛完成第一步交換的最大值蓄坏。對(duì)于數(shù)組來(lái)說(shuō),剛好是將最大值丑念,固定在最后的索引上涡戳。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市渠欺,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌椎眯,老刑警劉巖挠将,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異编整,居然都是意外死亡舔稀,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門掌测,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)内贮,“玉大人,你說(shuō)我怎么就攤上這事汞斧∫褂簦” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵粘勒,是天一觀的道長(zhǎng)竞端。 經(jīng)常有香客問(wèn)我,道長(zhǎng)庙睡,這世上最難降的妖魔是什么事富? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮乘陪,結(jié)果婚禮上统台,老公的妹妹穿的比我還像新娘。我一直安慰自己啡邑,他們只是感情好贱勃,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著谤逼,像睡著了一般募寨。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上森缠,一...
    開(kāi)封第一講書(shū)人閱讀 51,708評(píng)論 1 305
  • 那天拔鹰,我揣著相機(jī)與錄音,去河邊找鬼贵涵。 笑死列肢,一個(gè)胖子當(dāng)著我的面吹牛恰画,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播瓷马,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼拴还,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了欧聘?” 一聲冷哼從身側(cè)響起片林,我...
    開(kāi)封第一講書(shū)人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎怀骤,沒(méi)想到半個(gè)月后费封,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蒋伦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年弓摘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片痕届。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡韧献,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出研叫,到底是詐尸還是另有隱情锤窑,我是刑警寧澤,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布嚷炉,位于F島的核電站果复,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏渤昌。R本人自食惡果不足惜虽抄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望独柑。 院中可真熱鬧迈窟,春花似錦、人聲如沸忌栅。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)索绪。三九已至湖员,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瑞驱,已是汗流浹背娘摔。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留唤反,地道東北人凳寺。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓鸭津,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親肠缨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子逆趋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355