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

            隨感而發

            雜七雜八

            統計

            留言簿(13)

            閱讀排行榜

            評論排行榜

            基數排序

            今天學了基數排序,據說他的時間復雜度也是O(n),他的思路就是:
            沒有計數排序那么理想,我們的數據都比較集中,都比較大,一般是4,5位。基本沒有小的數據。
            那我們的處理很簡單,你不是沒有小的數據嘛。我給一個基數,例如個位,個位都是[0-10)范圍內的。先對他進行歸類,把小的放上面,大的放下面,然后個位排好了,在來看10位,我們也這樣把小的放上面,大的放下面,依次內推,直到最高位排好。那么不就排好了嗎?我們只需要做d(基數個數)的循環就可以了。時間復雜度相當于O(d * n) 因為d為常量,例如5位數,d就是5.所以近似為O(n)的時間復雜度。這次自己寫個案例:

            最初的數據

            排好個位的數據

            排好十位的數據

            排好百位的數據

            981

            981

            725

            129

            387

            753

            129

            387

            753

            955

            753

            456

            129

            725

            955

            725

            955

            456

            456

            753

            725

            387

            981

            955

            456

            129

            387

            981

            這里只需循環3次就出結果了。

            <!--[if !supportLists]-->3.       <!--[endif]-->但是注意,我們必須要把個位排好。但是個位怎么排呢?這個是個問題。書上說的是一疊一疊的怎么合并,我是沒有理解的。希望知道的有高手教我一下。

            我是用的一個計數排序來排各位的,然后排十位。效率應該也低不到哪里去。呵呵。。

            思路就這樣咯。奉上源代碼:

             

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

            //計數排序,npRadix為對應的關鍵字序列,nMax是關鍵字的范圍。npData是具體要
            //排的數據,nLen是數據的范圍,這里必須注意npIndex和npData對應的下標要一致
            //也就是說npIndex[1] 所對應的值為npData[1]
            int RadixCountSort(int* npIndex, int nMax, int* npData, int nLen)
            {
                
            //這里就不用說了,計數的排序。不過這里為了是排序穩定
                
            //在標準的方法上做了小修改。

                
            int* pnCount  = (int*)malloc(sizeof(int)* nMax);        //保存計數的個數
                for (int i = 0; i < nMax; ++i)
                {
                    pnCount[i] 
            = 0;
                }
                
            for (int i = 0; i < nLen; ++i)    //初始化計數個數
                {
                    
            ++pnCount[npIndex[i]];
                }

                
            for (int i = 1; i < 10++i)  //確定不大于該位置的個數。
                {
                    pnCount[i] 
            += pnCount[i - 1];
                }

                
            int * pnSort  = (int*)malloc(sizeof(int* nLen);    //存放零時的排序結果。

                
            //注意:這里i是從nLen-1到0的順序排序的,是為了使排序穩定。
                for (int i = nLen - 1; i >= 0--i)
                {
                    
            --pnCount[npIndex[i]];        
                    pnSort[pnCount[npIndex[i]]] 
            = npData[i];
                }

                
            for (int i = 0; i < nLen; ++i)        //把排序結構輸入到返回的數據中。
                {
                    npData[i] 
            = pnSort[i];
                }
                free(pnSort);                        
            //記得釋放資源。
                free(pnCount);
                
            return 1;
            }

            //基數排序
            int RadixSort(int* nPData, int nLen)
            {
                
            //申請存放基數的空間
                int* nDataRadix    = (int*)malloc(sizeof(int* nLen);

                
            int nRadixBase = 1;    //初始化倍數基數為1
                bool nIsOk = false//設置完成排序為false

                
            //循環,知道排序完成
                while (!nIsOk)
                {
                    nIsOk 
            = true;
                    nRadixBase 
            *= 10;
                    
            for (int i = 0; i < nLen; ++i)
                    {
                        nDataRadix[i] 
            = nPData[i] % nRadixBase;
                        nDataRadix[i] 
            /= nRadixBase / 10;
                        
            if (nDataRadix[i] > 0)
                        {
                            nIsOk 
            = false;
                        }
                    }
                    
            if (nIsOk)        //如果所有的基數都為0,認為排序完成,就是已經判斷到最高位了。
                    {
                        
            break;
                    }
                    RadixCountSort(nDataRadix, 
            10, nPData, nLen);
                }

                free(nDataRadix);

                
            return 1;
            }

            int main()
            {
                
            //測試基數排序。
                int nData[10= {123,5264,9513,854,9639,1985,159,3654,8521,8888};
                RadixSort(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:36 shongbee2 閱讀(13425) 評論(2)  編輯 收藏 引用 所屬分類: 數據結構和算法

            評論

            # re: 基數排序[未登錄] 2012-06-02 10:01 MICHAEL

            你的這個程序有一定的問題
            比如這組數據:
            int nData[10] = {1046,2084,9046,12074,56,7026,8099,17059,33,1};
              回復  更多評論   

            # re: 基數排序 2013-06-28 13:49 hum

            試了下,確實有點問題,修改一下就好了。
            修改前
            if (nDataRadix[i] > 0)
            {
            nIsOk = false;
            }
            修改后:
            if (nPData[i]/nRadixBase > 0)
            {
            nIsOk = false;
            }  回復  更多評論   

            天天综合久久久网| 久久久久香蕉视频| 久久国产精品99国产精| 久久免费小视频| 性做久久久久久免费观看| 亚洲人成伊人成综合网久久久 | 亚洲国产精品婷婷久久| 久久精品女人天堂AV麻| 久久精品人人槡人妻人人玩AV| 亚洲国产精久久久久久久| 欧美久久久久久| 曰曰摸天天摸人人看久久久| 一本色道久久综合狠狠躁| 国产精品欧美久久久久天天影视| 精品伊人久久久| 色综合久久久久综合体桃花网| 亚洲欧美成人综合久久久| 久久久午夜精品| 999久久久免费国产精品播放| 亚洲人成伊人成综合网久久久| 久久久无码精品亚洲日韩软件| 久久精品9988| 久久Av无码精品人妻系列| 亚洲精品乱码久久久久久自慰| 久久久久99精品成人片三人毛片 | 久久WWW免费人成—看片| 久久精品国产亚洲av水果派| 久久天天躁夜夜躁狠狠| 久久婷婷色综合一区二区| 51久久夜色精品国产| 精品免费tv久久久久久久| 热re99久久精品国99热| 青草国产精品久久久久久 | 色综合久久久久网| 久久这里只精品国产99热| 久久线看观看精品香蕉国产| 99久久99久久久精品齐齐 | av无码久久久久不卡免费网站 | 久久久久亚洲爆乳少妇无| 国产成人久久777777| 久久成人永久免费播放|