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

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品久久亚洲不卡动漫| 日韩十八禁一区二区久久 | 免费精品久久天干天干| 色婷婷久久久SWAG精品| 天堂久久天堂AV色综合| 久久综合九色综合欧美狠狠| 久久久久久久亚洲精品| 久久99精品久久久久久久不卡| 成人精品一区二区久久| 超级97碰碰碰碰久久久久最新| 久久国产免费观看精品| 香蕉aa三级久久毛片| 国产精品美女久久久久网| 亚洲精品国产自在久久| 久久亚洲高清观看| 亚洲国产精品久久电影欧美| 99久久国产综合精品成人影院 | 高清免费久久午夜精品| 青青草原综合久久大伊人| 久久精品这里热有精品| 伊人久久精品无码二区麻豆| 久久久久久久国产免费看| 国内精品久久久久久野外| 亚洲日韩中文无码久久| 亚洲国产天堂久久久久久| 国产精品VIDEOSSEX久久发布| 久久精品国产亚洲AV电影| 中文无码久久精品| 久久久久高潮综合影院| 久久亚洲国产成人影院| 国产精品日韩深夜福利久久| 久久婷婷五月综合97色| 99久久国产亚洲综合精品| 亚洲国产精品综合久久一线 | 久久99精品综合国产首页| 无码久久精品国产亚洲Av影片| 一本一道久久a久久精品综合 | 亚洲国产美女精品久久久久∴| 蜜臀久久99精品久久久久久| 亚洲国产成人精品无码久久久久久综合 | 久久久久亚洲AV无码永不|