• <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免费看图片| 少妇久久久久久被弄高潮| 国产精品免费久久久久久久久| 久久天堂电影网| 伊人久久大香线蕉综合5g| 九九久久99综合一区二区| 狠狠综合久久综合中文88| 亚洲va久久久噜噜噜久久狠狠| 一本久久久久久久| 久久婷婷五月综合国产尤物app| 精品国产一区二区三区久久| 久久亚洲中文字幕精品一区| 一本久久久久久久| AV无码久久久久不卡蜜桃| 久久久久久久女国产乱让韩| 久久精品成人免费国产片小草| 九九精品99久久久香蕉| 97精品国产97久久久久久免费| 久久精品国产只有精品66| 国产精品久久久久9999| 精品乱码久久久久久久| 久久天天躁夜夜躁狠狠躁2022| 久久久这里有精品中文字幕| 久久精品国产亚洲麻豆| 精品国产一区二区三区久久久狼| 蜜桃麻豆WWW久久囤产精品| 91亚洲国产成人久久精品网址| 久久久久久a亚洲欧洲aⅴ| 9久久9久久精品| 99久久国产免费福利| 欧美激情精品久久久久| 久久精品9988| 亚洲成色999久久网站| 青青青青久久精品国产| 久久久久久狠狠丁香| 91精品国产91热久久久久福利| 国产成人久久777777| 久久久黄片| 色狠狠久久综合网| 色综合久久久久久久久五月| 久久发布国产伦子伦精品 |