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

            liyuxia713

            蹣跚前行者

            常用鏈接

            統計

            Algorithms

            C++

            最新評論

            基本排序方法及分析(八):CoungtingSort 計數排序

            計數排序對a[0],...,a[n-1]進行排序,其中1 <= a[i] <= m
            計數排序不是基于比較的排序方法,從而最壞情形下的運行時間也不受比較的排序方法最快O(nlgn)的限制。
            計數排序的運行時間是O(n+m)

             1/**
             2 * Countying sort計數排序
             3 * 對a[0],,a[n-1]進行排序,其中1 <= a[i] <= m 
             4 */
             
             5
             6#include <iostream> 
             7#include <cstdlib>
             8
             9using namespace std; 
            10
            11void print(int* a , int n)
            12{
            13     for(int i = 0; i < n ; i++)
            14             cout << a[i];
            15     cout << endl;
            16}

            17
            18//對a[0],,a[n-1]進行排序,其中1 <= a[i] <= m 
            19void Counting_Sort(int *a, int n , int m)
            20{
            21     int *= new int[m];
            22     int *temp = new int[n];
            23     
            24     //初始設為0 
            25     for(int i = 0; i < m ; i++)
            26     {
            27             c[i] = 0;
            28     }
              
            29     
            30     //c[i-1]中存儲值為i的個數 
            31     for(int i = 0; i < n; i++)
            32     {
            33             c[a[i]-1+= 1;             
            34     }

            35        
            36     //c[i-1]中存儲值小于等于i的個數 
            37     for(int i = 1; i < m; i++
            38     {
            39             c[i] = c[i] + c[i-1];
            40     }
               
            41     
            42     //排序 
            43     for(int i = n-1; i >= 0; i--)
            44     
            45             temp[c[a[i]-1]-1= a[i];
            46             c[a[i]-1]--;
            47     }
                
            48      
            49     //從臨時數組轉到a 
            50     for(int i = 0; i < n; i++)
            51     {
            52             a[i] = temp[i];
            53     }

            54}

            55
            56int main()
            57{
            58    int a[5= {4,1,3,4,3};
            59   
            60    print(a,5);
            61   
            62    Counting_Sort(a,5,4);
            63   
            64    print(a,5); 
            65   
            66    system("pause");
            67    return 0;
            68}
             
            69
            70

            posted on 2010-01-18 15:50 幸運草 閱讀(440) 評論(0)  編輯 收藏 引用 所屬分類: Algorithms

            久久久精品国产亚洲成人满18免费网站| 中文字幕久久精品无码| 免费观看成人久久网免费观看| 青青青青久久精品国产h| 久久久精品人妻无码专区不卡| 久久久精品国产| 成人久久精品一区二区三区| 国产精品无码久久四虎| 国产精品久久久久蜜芽| 国产毛片欧美毛片久久久| 国内精品久久久久影院一蜜桃 | 亚洲精品无码久久久久AV麻豆| 99精品国产免费久久久久久下载| 久久精品国产亚洲av日韩| 精品久久久久久国产三级| 国产午夜福利精品久久2021| 久久国产成人午夜aⅴ影院 | 蜜臀久久99精品久久久久久小说| 国产福利电影一区二区三区久久久久成人精品综合 | 午夜不卡888久久| 狠狠色丁香久久婷婷综合| 久久精品国产99久久久香蕉| 国产91久久精品一区二区| 精品久久人人爽天天玩人人妻| 国产AV影片久久久久久| 91久久婷婷国产综合精品青草 | 老色鬼久久亚洲AV综合| 久久综合鬼色88久久精品综合自在自线噜噜 | 99久久精品国产一区二区蜜芽 | 久久久久久免费视频| 久久高潮一级毛片免费| 国产欧美一区二区久久| 久久亚洲AV成人无码电影| 国产成人久久精品一区二区三区| 久久婷婷人人澡人人| 久久亚洲2019中文字幕| 久久久这里有精品中文字幕| 久久夜色精品国产亚洲av| 亚洲国产成人久久综合野外| 无码任你躁久久久久久| 亚洲天堂久久久|