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

            A Za, A Za, Fighting...

            堅信:勤能補拙

            2011排序-堆排序

            堆排序: 時間復雜度 O(nlogn),非穩定排序

            比如:3 27 36 27
            如果堆頂3先輸出,則,第三層的27(最后一個27)跑到堆頂,然后堆穩定,繼續輸出堆頂,是剛才那個27,這樣說明后面的27先于第二個位置的27輸出,不穩定。

            #define LEFT(i) (((i)<<1)+1)
            #define RIGHT(i) (((i)+1)<<1)
            #define PARENT(i) (((i)-1)>>1)

            void
            min_heapify(
            int index, int *heap, int heap_size) //precondition: LEFT(index) and RIGHT(index) are both already min-heap
            {
                
            int min = index;
                
            if(LEFT(index)<heap_size && heap[LEFT(index)]<heap[min])
                    min 
            = LEFT(index);
                
            if(RIGHT(index)<heap_size && heap[RIGHT(index)]<heap[min])
                    min 
            = RIGHT(index);

                
            if(min != index) {
                    swap(heap
            +min, heap+index);
                    min_heapify(min, heap, heap_size);
                }
            }

            void
            build_heap(
            int *heap, int heap_size)
            {
                
            int i = (heap_size>>1);
                
            for( ; i>=0--i)
                    min_heapify(i, heap, heap_size);
            }

            void
            heap_sort(
            int *heap, int heap_size)
            {
                build_heap(heap, heap_size);

                
            while(heap_size > 1) {
                    swap(heap, heap
            +heap_size-1);
                    
            --heap_size;
                    min_heapify(
            0, heap, heap_size);
                }
            }

            posted on 2011-07-29 20:25 simplyzhao 閱讀(100) 評論(0)  編輯 收藏 引用 所屬分類: R_找工復習2011

            導航

            <2010年10月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久人妻少妇嫩草AV无码蜜桃| 亚洲精品97久久中文字幕无码| 亚洲第一永久AV网站久久精品男人的天堂AV| 久久久久久精品免费免费自慰| 精品永久久福利一区二区| 久久亚洲精品国产精品| 91久久成人免费| 久久天天躁狠狠躁夜夜2020一| 伊人久久综合成人网| 九九久久精品国产| 伊人久久大香线蕉综合Av| 九九久久精品无码专区| 久久久一本精品99久久精品88| 88久久精品无码一区二区毛片| 2021国内精品久久久久久影院| 免费国产99久久久香蕉| 亚洲国产精品无码久久久蜜芽 | 精品熟女少妇a∨免费久久| 久久99精品久久久久久不卡| 亚洲国产一成人久久精品| 人妻少妇精品久久| 99久久精品九九亚洲精品| av国内精品久久久久影院| 热综合一本伊人久久精品| 久久国产精品免费| 精品久久久久久中文字幕| 久久亚洲精品中文字幕| 国产成人无码精品久久久性色 | 精品国产福利久久久| 亚洲伊人久久精品影院| 欧美亚洲国产精品久久久久| 久久精品亚洲精品国产欧美| 久久无码av三级| 婷婷久久综合九色综合98| 国产精品久久国产精麻豆99网站| 亚洲国产精品无码久久久不卡| 狠狠色婷婷久久一区二区| 亚洲色欲久久久综合网东京热| 久久久久免费精品国产| 欧洲精品久久久av无码电影 | 久久精品亚洲AV久久久无码|