青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨感而發

雜七雜八

統計

留言簿(13)

閱讀排行榜

評論排行榜

計數排序,傳說時間復雜度為0(n)的排序

計數排序:

今天學習了計數排序,貌似計數排序的復雜度為o(n)。很強大。他的基本思路為:

1.       我們希望能線性的時間復雜度排序,如果一個一個比較,顯然是不實際的,書上也在決策樹模型中論證了,比較排序的情況為nlogn的復雜度。

2.       既然不能一個一個比較,我們想到一個辦法,就是如果我在排序的時候就知道他的位置,那不就是掃描一遍,把他放入他應該的位置不就可以了嘛。

3.       要知道他的位置,我們只需要知道有多少不大于他不就可以了嗎?

4.       以此為出發點,我們怎么確定不大于他的個數呢?我們先來個約定,如果數組中的元素都比較集中,都在[0, max]范圍內。我們開一個max的空間b數組,把b數組下標對應的元素和要排序的A數組下標對應起來。這樣不就可以知道不比他大的有多少個了嗎?我們只要把比他小的位置元素個數求和,就是不比他大的。例如:A={3,5,7};我們開一個大小為8的數組b,把a[0] = 3 放入b[3]中,使b[3] = 0; 同理 b[5] = 1; b[7] = 2;其他我們都設置為-1,哈哈我們只需要遍歷一下b數組,如果他有數據,就來出來,鐵定是當前最小的。如果要知道比a[2]小的數字有多少個,值只需要求出b[0] – b[6]的有數據的和就可以了。這個0(n)的速度不是蓋得。

5.       思路就是這樣咯。但是要注意兩個數相同的情況A = {1,2,3,3,4},這種情況就不可以咯,所以還是有點小技巧的。

6.       處理小技巧:我們不把A的元素大小與B的下標一一對應,而是在B數組對應處記錄該元素大小的個數。這不久解決了嗎。哈哈。例如A = {1,2,3,3,4}我們開大小為5的數組b;記錄數組A中元素值為0的個數為b[0] = 0, 記錄數組A中元素個數為1的b[1] = 1,同理b[2] = 1, b[3] = 2, b[4] = 1;好了,這樣我們就知道比A[4](4)小的元素個數是多少了:count = b[0] + b[1] + b[2] + b[3] = 4;他就把A[4]的元素放在第4個位置。

還是截張書上的圖:

再次推薦《算法導論》這本書,在我的上次的隨筆中有下載鏈接。哈哈。真正支持還是需要買一下紙版。呵呵。

7. 不過在編程的時候還是要注意細節的,例如我不能每次都來算一下比他小的個數。呵呵,思路就這樣了。奉上源代碼:

 

#include <stdio.h>
#include 
<stdlib.h>

//計數排序
int CountSort(int* pData, int nLen)
{
    
int* pCout = NULL;            //保存記數數據的指針
    pCout = (int*)malloc(sizeof(int* nLen);    //申請空間
    
//初始化記數為0
    for (int i = 0; i < nLen; ++i)
    {
        pCout[i] 
= 0;
    }

    
//記錄排序記數。在排序的值相應記數加1。
    for (int i = 0; i < nLen; ++i)
    {
        
++pCout[pData[i]];        //
    }

    
//確定不比該位置大的數據個數。
    for (int i = 1; i < nLen; ++i)
    {
        pCout[i] 
+= pCout[i - 1];    //不比他大的數據個數為他的個數加上前一個的記數。
    }

    
int* pSort = NULL;            //保存排序結果的指針
    pSort = (int*)malloc(sizeof(int* nLen);    //申請空間

    
for (int i = 0; i < nLen; ++i)
    {
        
//把數據放在指定位置。因為pCout[pData[i]]的值就是不比他大數據的個數。
        
//為什么要先減一,因為pCout[pData[i]]保存的是不比他大數據的個數中包括了
        
//他自己,我的下標是從零開始的!所以要先減一。
        --pCout[pData[i]];    //因為有相同數據的可能,所以要把該位置數據個數減一。
        pSort[pCout[pData[i]]] = pData[i];        
        
    }

    
//排序結束,復制到原來數組中。
    for (int i = 0; i < nLen; ++i)
    {
        pData[i] 
= pSort[i];
    }

    
//最后要注意釋放申請的空間。
    free(pCout);
    free(pSort);

    
return 1;
}

int main()
{
    
int nData[10= {8,6,3,6,5,8,3,5,1,0};
    CountSort(nData, 
10);
    
for (int i = 0; i < 10++i)
    {
        printf(
"%d ", nData[i]);
    }
    printf(
"\n");

    system(
"pause");
    
return 0;
}


posted on 2009-04-24 21:11 shongbee2 閱讀(21377) 評論(12)  編輯 收藏 引用 所屬分類: 數據結構和算法

評論

# re: 計數排序,傳說時間復雜度為0(n)的排序 2010-04-01 11:05 h

怎么看來和桶排序沒有區別啊!!!  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序 2010-10-24 18:07 路過

真的是以空間換時間的操作,確實比較快,但是應該是對已知范圍的序列進行排序吧,否則,如果是10個數分別是1,2,3,4,5,6,7,8,9,100000000,那浪費了多少空間啊  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序 2011-04-13 15:02 SHinee

以空間換時間,很經典的算法,但不得不說你的程序是對的么,如果有個負數呢,如果有個數較大呢,pCout數組的空間大小不應該是nLen啊...你考慮的太片面了  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序[未登錄] 2011-09-07 16:01 sue

排序結束前的for,應該是i=nlen-1,i>0,i--?  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序 2011-11-11 20:26 pippoflow

計數排序本來就是針對事先對待排序數據有了解,即這些數是如何分布的。
如果有負數或者有少量數極大,當然不適合用計數排序@SHinee  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序 2012-05-09 14:43 代碼之美

當待排序數中最大值Max大于待排數序列長度時,樓主的程序就失效啦!我用C++修改了下樓主的代碼--計數數組長度改為Max,這一問題得到了解決。  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序 2012-08-14 15:35 jizhugou

不是以空間換時間,所需時間是O(n+k),n為待排序個數,k為數的范圍。倘若k很大,則空間很大,時間也很大。若k遠遠大于n,則空間浪費了,時間也沒省。若k和n相差不太多,則空間也不會浪費太多。  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序 2013-07-24 17:00 ge

@路過
你說的這種就不適用了,計數算法有自己的優勢場景。如果數據差距很大,就不適合了。  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序 2013-07-24 17:03 ge

@pippoflow
對頭,贊一個。
  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序[未登錄] 2013-09-29 16:42 skywalker

直接根據計數表里非零元素的計數值,遍歷計數表,把每個非零元素計數值這么多個數值直接寫回原數組,這樣更快。  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序[未登錄] 2013-09-29 16:45 skywalker

更正,把每個非零元素計數值這么多個數值的 腳標 直接寫回原數組  回復  更多評論   

# re: 計數排序,傳說時間復雜度為0(n)的排序 2016-04-10 19:23 cir

@路過
不可以離散化一下嗎?  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            黄色综合网站| 欧美三日本三级三级在线播放| 国产精品一区二区久久久久| 亚洲午夜在线观看| 亚洲一区二区三区在线| 国产精品丝袜久久久久久app| 欧美在线亚洲在线| 久久久av水蜜桃| 99国产精品久久久久老师| 999在线观看精品免费不卡网站| 欧美视频成人| 久久免费偷拍视频| 欧美成人免费全部| 午夜宅男久久久| 裸体歌舞表演一区二区| 一个色综合导航| 嫩草伊人久久精品少妇av杨幂| 国产精品久久一卡二卡| 欧美专区18| 久久综合色88| 亚洲一级在线观看| 久久精品国产亚洲a| 99精品视频一区二区三区| 亚洲永久免费av| 亚洲精品在线视频| 校园春色综合网| 9l国产精品久久久久麻豆| 午夜一区二区三视频在线观看 | 国产农村妇女精品| 牛夜精品久久久久久久99黑人| 欧美日韩hd| 久久综合一区| 国产精品腿扒开做爽爽爽挤奶网站| 美女91精品| 国产乱码精品一区二区三区五月婷| 欧美激情一区二区三区在线视频观看 | 欧美亚洲日本一区| 中日韩在线视频| 久久综合婷婷| 久久精品国产99精品国产亚洲性色| 欧美另类极品videosbest最新版本| 久久在线视频在线| 国产精品一二三四区| 亚洲精品免费电影| 在线看日韩欧美| 欧美一区二区日韩| 午夜宅男久久久| 国产精品v欧美精品∨日韩| 亚洲夫妻自拍| 亚洲国产精品激情在线观看| 性高湖久久久久久久久| 亚洲在线成人| 国产精品扒开腿做爽爽爽视频| 亚洲激情欧美激情| 91久久精品日日躁夜夜躁欧美 | 欧美伦理视频网站| 亚洲高清视频在线| 亚洲欧洲精品一区二区三区| 久久综合国产精品台湾中文娱乐网| 久久久久久久久久看片| 国产视频不卡| 欧美资源在线| 老司机一区二区三区| 精品成人一区二区三区四区| 久久精品人人爽| 欧美二区不卡| 亚洲精品乱码久久久久久久久| 欧美成人a视频| 亚洲经典三级| 亚洲网友自拍| 国产精品毛片va一区二区三区 | 欧美成人蜜桃| 亚洲三级免费| 欧美一区二区三区在线播放| 麻豆国产精品777777在线| 久久这里有精品视频| 在线精品一区| 欧美激情综合五月色丁香小说| 91久久久亚洲精品| 亚洲尤物在线视频观看| 国产精品视频九色porn| 欧美一级视频| 亚洲电影毛片| 亚洲一区二三| 国内精品久久久久久影视8| 久久五月激情| 一区二区三区 在线观看视| 亚洲欧美一区二区视频| 国产一区激情| 欧美成人午夜免费视在线看片 | 在线一区二区三区四区| 欧美亚洲综合久久| 亚洲电影免费在线观看| 欧美精品免费播放| 新狼窝色av性久久久久久| 欧美成人久久| 欧美一区二区三区日韩| 亚洲国产精品成人| 国产精品免费福利| 久久嫩草精品久久久精品| 一本在线高清不卡dvd| 久久婷婷国产综合精品青草| 99re8这里有精品热视频免费 | 国产精品免费一区豆花| 久久久777| 在线亚洲欧美视频| 欧美国产极速在线| 欧美中文在线视频| 夜夜嗨av一区二区三区中文字幕| 国产农村妇女毛片精品久久莱园子| 免费人成精品欧美精品| 亚洲免费影视| 日韩亚洲欧美精品| 欧美国产免费| 久久夜色撩人精品| 午夜精品福利一区二区蜜股av| 亚洲黄色成人| 激情综合色综合久久综合| 欧美视频中文字幕| 欧美精品久久久久久久久老牛影院 | 欧美在线观看一区二区三区| 9色国产精品| 亚洲国产欧洲综合997久久| 久久精品一区二区三区四区| 一区二区三区不卡视频在线观看 | 欧美一区二区三区的| 一区二区三区欧美成人| 91久久精品日日躁夜夜躁国产| 久久综合狠狠综合久久综合88| 亚洲摸下面视频| 亚洲午夜精品一区二区三区他趣| 91久久精品网| 亚洲区一区二| 亚洲专区国产精品| 日韩一区二区精品视频| 欧美高清免费| 欧美视频一区二区三区…| 免费亚洲网站| 欧美超级免费视 在线| 久久尤物视频| 久久久久久久综合色一本| 午夜宅男欧美| 午夜久久影院| 久久成人一区二区| 久久精品亚洲一区| 久久人91精品久久久久久不卡| 久久成人这里只有精品| 久久狠狠久久综合桃花| 欧美中文字幕视频在线观看| 久久精品三级| 久久激情网站| 欧美jizzhd精品欧美巨大免费| 免播放器亚洲一区| 欧美激情第9页| 国产精品久久久对白| 国产精品一区2区| 黄色日韩精品| 亚洲国产清纯| 亚洲一区二区三区色| 性欧美精品高清| 免费亚洲电影| 日韩手机在线导航| 亚洲欧美综合精品久久成人| 欧美自拍偷拍午夜视频| 欧美777四色影视在线| 欧美高清不卡在线| 国产精品嫩草久久久久| 国产日本欧美一区二区三区| 激情欧美一区二区三区| 日韩特黄影片| 香蕉免费一区二区三区在线观看| 久久免费国产精品1| 亚洲国产精品一区二区久| 99亚洲一区二区| 久久精品国产99| 欧美日韩国产一区精品一区| 国产日产欧产精品推荐色 | 亚洲字幕一区二区| 老司机一区二区| 国产精品v日韩精品| 国产综合久久久久影院| 99精品欧美一区二区蜜桃免费| 久久aⅴ国产欧美74aaa| 亚洲第一区中文99精品| 午夜久久美女| 欧美肉体xxxx裸体137大胆| 激情综合色综合久久| 亚洲欧美日韩系列| 亚洲国产婷婷| 久久精品五月婷婷| 国产精品v欧美精品v日韩| 在线观看亚洲精品视频| 亚洲欧美日韩国产中文| 亚洲第一成人在线| 久久av一区二区| 国产精品区二区三区日本 | 红桃视频一区| 欧美影院成人| 一区二区三区国产在线| 免费视频一区二区三区在线观看|