• <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 閱讀(13423) 評論(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;
            }  回復  更多評論   

            AV无码久久久久不卡网站下载| 精品人妻伦一二三区久久| 国产A三级久久精品| 色综合久久久久无码专区| 精品久久久久久久| 狠狠色丁香久久婷婷综合_中| 久久66热人妻偷产精品9| 人妻中文久久久久| 国内精品久久久久伊人av| 亚洲一区精品伊人久久伊人 | 色综合久久精品中文字幕首页| 久久精品无码一区二区app| 欧洲精品久久久av无码电影| 久久影视综合亚洲| 国产精品无码久久综合| 久久久久久久久久久精品尤物| 亚洲国产成人久久综合一 | 伊人热热久久原色播放www | 国产精品中文久久久久久久| 久久精品国产91久久麻豆自制| 伊人久久综合精品无码AV专区| 精品久久久久久无码中文字幕 | 久久五月精品中文字幕| 香蕉久久夜色精品国产小说| 欧洲人妻丰满av无码久久不卡| 久久久久综合中文字幕| 国产精品99久久久久久宅男| 97精品伊人久久久大香线蕉| 国产精品久久久久9999高清| 国产亚洲综合久久系列| 久久99精品久久只有精品| 久久久久亚洲精品日久生情| 国产精品成人久久久| 一本色综合久久| 久久精品桃花综合| 国产欧美久久久精品影院| 日产精品久久久久久久| 亚洲欧美日韩久久精品第一区| 日产精品久久久久久久| 久久精品午夜一区二区福利| 久久精品中文騷妇女内射|