• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            那誰(shuí)的技術(shù)博客

            感興趣領(lǐng)域:高性能服務(wù)器編程,存儲(chǔ),算法,Linux內(nèi)核
            隨筆 - 210, 文章 - 0, 評(píng)論 - 1183, 引用 - 0
            數(shù)據(jù)加載中……

            常見(jiàn)排序算法的實(shí)現(xiàn)(三)-堆排序

            堆的定義:???  
            ?????????n個(gè)關(guān)鍵字序列Kl,K2,…,Kn稱(chēng)為堆,當(dāng)且僅當(dāng)該序列滿足如下性質(zhì)(簡(jiǎn)稱(chēng)為堆性質(zhì)):
            ???  (1) ki≤K2i且ki≤K2i+1 或(2)Ki≥K2i且ki≥K2i+1(1≤i≤)

            ???  若將此序列所存儲(chǔ)的向量R[1..n]看做是一棵完全二叉樹(shù)的存儲(chǔ)結(jié)構(gòu),則堆實(shí)質(zhì)上是滿足如下性質(zhì)的完全二叉樹(shù):樹(shù)中任一非葉結(jié)點(diǎn)的關(guān)鍵字均不大于(或不小于)其左右孩子(若存在)結(jié)點(diǎn)的關(guān)鍵字。

            ?????????堆的這個(gè)性質(zhì)使得可以迅速定位在一個(gè)序列之中的最小(大)的元素.

            ?????????堆排序算法的過(guò)程如下:1)得到當(dāng)前序列的最小(大)的元素 2)把這個(gè)元素和最后一個(gè)元素進(jìn)行交換,這樣當(dāng)前的最小(大)的元素就放在了序列的最后,而原先的最后一個(gè)元素放到了序列的最前面 3)的交換可能會(huì)破壞堆序列的性質(zhì)(注意此時(shí)的序列是除去已經(jīng)放在最后面的元素),因此需要對(duì)序列進(jìn)行調(diào)整,使之滿足于上面堆的性質(zhì).重復(fù)上面的過(guò)程,直到序列調(diào)整完畢為止.
            //?array是待調(diào)整的堆數(shù)組,i是待調(diào)整的數(shù)組元素的位置,length是數(shù)組的長(zhǎng)度
            void?HeapAdjust(
            int?array[],?int?i,?int?nLength)
            {
            ????
            int?nChild,?nTemp;

            ????
            for?(nTemp?=?array[i];?2?*?i?+?1?<?nLength;?i?=?nChild)
            ????{
            ????????
            //?子結(jié)點(diǎn)的位置是?父結(jié)點(diǎn)位置?*?2?+?1
            ????????nChild?
            =?2?*?i?+?1;

            ????????
            //?得到子結(jié)點(diǎn)中較大的結(jié)點(diǎn)
            ????????
            if?(nChild?!=?nLength?-?1?&&?array[nChild?+?1]?>?array[nChild])
            ????????????
            ++nChild;

            ????????
            //?如果較大的子結(jié)點(diǎn)大于父結(jié)點(diǎn)那么把較大的子結(jié)點(diǎn)往上移動(dòng),替換它的父結(jié)點(diǎn)
            ????????
            if?(nTemp?<?array[nChild])
            ????????{
            ????????????
            array[i]?=?array[nChild];
            ????????}
            ????????
            else????//?否則退出循環(huán)
            ????????{
            ????????????break;
            ????????}
            ????}

            ????
            //?最后把需要調(diào)整的元素值放到合適的位置
            ????
            array[i]?=?nTemp;
            }

            //?堆排序算法
            void?HeapSort(
            int?array[],?int?length)
            {
            ????
            //?調(diào)整序列的前半部分元素,調(diào)整完之后第一個(gè)元素是序列的最大的元素
            ????
            for?(int?i?=?length?/?2?-?1;?i?>=?0;?--i)
            ????{
            ????????HeapAdjust(
            array,?i,?length);
            ????}

            ????
            //?從最后一個(gè)元素開(kāi)始對(duì)序列進(jìn)行調(diào)整,不斷的縮小調(diào)整的范圍直到第一個(gè)元素
            ????
            for?(int?i?=?length?-?1;?i?>?0;?--i)
            ????{
            ????????
            //?把第一個(gè)元素和當(dāng)前的最后一個(gè)元素交換,
            ????????
            //?保證當(dāng)前的最后一個(gè)位置的元素都是在現(xiàn)在的這個(gè)序列之中最大的
            ????????Swap(
            &array[0],?&array[i]);

            ????????
            //?不斷縮小調(diào)整heap的范圍,每一次調(diào)整完畢保證第一個(gè)元素是當(dāng)前序列的最大值
            ????????HeapAdjust(
            array,?0,?i);
            ????}
            }

            一個(gè)測(cè)試及輸出的結(jié)果,在每次HeapAdjust之后顯示出來(lái)當(dāng)前數(shù)組的情況
            before?Heap?sort:
            71?18?151?138?160?63?174?169?79?78?
            //?開(kāi)始調(diào)整前半段數(shù)組元素
            71?18?151?138?160?63?174?169?79?78?
            71?18?151?169?160?63?174?138?79?78?
            71?18?174?169?160?63?151?138?79?78?
            71?169?174?138?160?63?151?18?79?78?
            174?169?151?138?160?63?71?18?79?78?
            //?開(kāi)始進(jìn)行全局的調(diào)整
            169?160?151?138?78?63?71?18?79?174?
            160?138?151?79?78?63?71?18?169?174?
            151?138?71?79?78?63?18?160?169?174?
            138?79?71?18?78?63?151?160?169?174?
            79?78?71?18?63?138?151?160?169?174?
            78?63?71?18?79?138?151?160?169?174?
            71?63?18?78?79?138?151?160?169?174?
            63?18?71?78?79?138?151?160?169?174?
            18?63?71?78?79?138?151?160?169?174?


            動(dòng)畫(huà)演示:
            http://202.113.89.254/DataStructure/DS/web/flashhtml/duipaixu.htm

            posted on 2006-07-03 16:56 那誰(shuí) 閱讀(1273) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 算法與數(shù)據(jù)結(jié)構(gòu)

            久久夜色精品国产www| 国产精品久久国产精品99盘 | 久久香蕉国产线看观看精品yw| 丁香久久婷婷国产午夜视频| 精品九九久久国内精品| 久久99精品国产自在现线小黄鸭| 亚洲精品无码久久久久sm| 亚洲精品蜜桃久久久久久| 伊人久久精品无码av一区| 一本久久知道综合久久| 久久久国产精品亚洲一区 | 午夜天堂av天堂久久久| 伊人久久综合无码成人网| 亚洲AV无码成人网站久久精品大| 一个色综合久久| 久久久久亚洲AV无码网站| 97久久超碰国产精品2021| 国产午夜精品理论片久久| 久久久久久久国产免费看| 奇米影视7777久久精品人人爽| 久久久久久久97| 青青青青久久精品国产| 欧美久久一区二区三区| 色婷婷久久综合中文久久蜜桃av| 狠狠色丁香久久婷婷综| 久久久久亚洲精品中文字幕| 狠狠色狠狠色综合久久 | 亚洲国产精品久久66| 久久综合五月丁香久久激情| 国产成人无码精品久久久性色| 激情伊人五月天久久综合| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区| 青青青青久久精品国产 | 韩国三级中文字幕hd久久精品| 色欲综合久久躁天天躁| 久久人人爽人人爽人人片av高请| 国产精品久久永久免费| 中文成人久久久久影院免费观看| 久久精品www人人爽人人| 无码精品久久一区二区三区 | 久久久久亚洲av无码专区|