• <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>

            那誰的技術博客

            感興趣領域:高性能服務器編程,存儲,算法,Linux內核
            隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
            數據加載中……

            常見排序算法的實現(三)-堆排序

            堆的定義:???  
            ?????????n個關鍵字序列Kl,K2,…,Kn稱為堆,當且僅當該序列滿足如下性質(簡稱為堆性質):
            ???  (1) ki≤K2i且ki≤K2i+1 或(2)Ki≥K2i且ki≥K2i+1(1≤i≤)

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

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

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

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

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

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

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

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

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

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

            一個測試及輸出的結果,在每次HeapAdjust之后顯示出來當前數組的情況
            before?Heap?sort:
            71?18?151?138?160?63?174?169?79?78?
            //?開始調整前半段數組元素
            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?
            //?開始進行全局的調整
            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?


            動畫演示:
            http://202.113.89.254/DataStructure/DS/web/flashhtml/duipaixu.htm

            posted on 2006-07-03 16:56 那誰 閱讀(1273) 評論(0)  編輯 收藏 引用 所屬分類: 算法與數據結構

            欧美亚洲日本久久精品| 国产精品欧美久久久久无广告 | 国产精品久久精品| 国内精品久久久久久不卡影院| 国内精品久久久久久久久电影网| 色偷偷88欧美精品久久久| 伊人久久大香线蕉亚洲五月天| 精品国产91久久久久久久| 久久久久亚洲AV成人网人人网站| 亚洲午夜久久久影院伊人| 久久最新精品国产| 亚洲va中文字幕无码久久| 91秦先生久久久久久久| 久久精品国产亚洲AV无码娇色 | 一级做a爰片久久毛片看看| 天天爽天天狠久久久综合麻豆| 久久99精品久久久久久齐齐| 97精品依人久久久大香线蕉97 | 日本精品久久久久影院日本| 97久久超碰国产精品2021| 久久91精品国产91| 久久综合九色欧美综合狠狠 | 99久久久国产精品免费无卡顿| 亚洲va久久久久| 精品久久久久久国产牛牛app| 国产69精品久久久久久人妻精品| 久久久国产一区二区三区| 久久99国产精品二区不卡| 久久偷看各类wc女厕嘘嘘| 中文字幕精品无码久久久久久3D日动漫| 色综合久久天天综合| 久久亚洲精品无码AV红樱桃| 无码超乳爆乳中文字幕久久| 亚洲中文字幕无码久久2020| 久久精品成人欧美大片| 精品久久亚洲中文无码| 国产亚洲精久久久久久无码77777| 亚洲第一永久AV网站久久精品男人的天堂AV| 久久99精品综合国产首页| 一级做a爱片久久毛片| 国内精品久久久久久久97牛牛 |