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

            堅(jiān)信:勤能補(bǔ)拙

            2011排序-堆排序

            堆排序: 時(shí)間復(fù)雜度 O(nlogn),非穩(wěn)定排序

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

            #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) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): R_找工復(fù)習(xí)2011

            導(dǎo)航

            <2011年7月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統(tǒng)計(jì)

            常用鏈接

            留言簿(1)

            隨筆分類(lèi)

            隨筆檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            偷窥少妇久久久久久久久| 青青久久精品国产免费看| 青青草原综合久久大伊人| 久久人人爽人人爽人人片AV麻烦 | 亚洲欧美日韩中文久久| 无码超乳爆乳中文字幕久久| 久久久久久a亚洲欧洲aⅴ| 亚州日韩精品专区久久久| 亚洲精品乱码久久久久久中文字幕 | 97久久香蕉国产线看观看| 精品99久久aaa一级毛片| 国产精品一区二区久久精品涩爱| 久久夜色精品国产噜噜噜亚洲AV| 久久精品无码专区免费| 久久精品国产亚洲AV电影| 久久这里有精品视频| 久久久久亚洲av无码专区| 青春久久| 26uuu久久五月天| 99久久精品费精品国产一区二区| yy6080久久| 老司机午夜网站国内精品久久久久久久久| 婷婷久久久亚洲欧洲日产国码AV | 亚洲欧美国产日韩综合久久| 97精品国产97久久久久久免费| 色婷婷综合久久久久中文| 超级碰碰碰碰97久久久久| 久久黄视频| 国产综合成人久久大片91| 日本一区精品久久久久影院| 99精品国产在热久久无毒不卡| 久久www免费人成看片| 国产精品久久久久久久人人看| 久久亚洲AV永久无码精品| 久久精品国产99久久久香蕉| 99精品伊人久久久大香线蕉| 色偷偷888欧美精品久久久| 久久99热精品| 九九久久精品国产| 久久精品人妻一区二区三区| 免费一级欧美大片久久网|