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

如何生成均勻隨機排列(等概率生成排列)

      這個算法的應用,比如洗牌,這個大家都非常熟悉。很久以前用的是最原始的方法,就是一直rand()未出現的牌,直至生成所有的牌。
這當然是一個while(1)循環,很爛的算法吧。后面聽說直接交換牌,打亂即可了。但是打亂后生成的排列是隨機的么,是等可能隨機的么。
其實,這個問題上算法導論上早已經有了答案了,看過算法導論之后覺得沒看之前真的是算法修養太差了。
      算法的偽代碼如下圖所示:
      
      
      具體c++實現如下:
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <time.h>
// void Swap(int& nOne, int& nTwo)
// {
// nOne = nOne + nTwo;
// nTwo = nOne - nTwo;
// nOne = nOne - nTwo;
// }
void Swap(int& nOne, int& nTwo)
{
    int nTemp;
    nTemp = nOne;
    nOne = nTwo;
    nTwo = nTemp;
}
//返回一個在區間[nBeg, nEnd]內的隨機數
int Random(int nBeg, int nEnd)
{
    assert(nEnd >= nBeg);
    if (nBeg == nEnd)
    {
        return nBeg;
    }
    else
    {
        return rand() % (nEnd - nBeg + 1) + nBeg;
    }
}
void RandomizeInPlace(int* pnA, int nLen)
{
    static bool s_bFirst = false;
    if (!s_bFirst)
    {
        srand(time(NULL));
        s_bFirst = true;
    }
    
    for (int i = 0; i < nLen; ++i)
    {
        Swap(pnA[i], pnA[Random(i, nLen - 1)]);
    }
}
int main()
{
    int nArray[20];
    int i, j;
    for (i = 1; i <= 20; ++i)
    {
        int nCnt = i;
        while (nCnt--)
        {
            for (j = 0; j < i; ++j)
            {
                nArray[j] = j;
            }
            RandomizeInPlace(nArray, i);
            for (j = 0; j < i; ++j)
            {
                printf("%d ", nArray[j]);
            }
            printf("\n");
        }
        printf("\n");
    }
    return 0;
}

   運行效果圖片如下:

   根據運行結果大致就可以感覺到,生成的排列都是隨機的。
   這里要多說一句那就是我注釋的那個交換函數其實是有bug的,也許這才是不提倡使用這個交換方法的真正原因,而不僅僅是
難以理解。用同一個變量去調用該函數,會將該變量置0,而不是保持原來的值!!!

   至于如何證明這個算法生成的均勻隨機的排列,可以參考算法導論5.3節最后一部分。
   證明的大致思路是利用循環不變式的證明方法:證明i次循環后得到某個排列的概論是(n -i)! / n!,那么n次循環后得到最終那個排列的
概論就是1/n!,這樣就證明了該算法能夠得到均勻隨機排列。
   這個算法其實就是隨機化算法的一種,其實快排也有所謂的隨機化版本,改動的地方只是隨機選擇了中軸元素而已,這個
在算法導論上也有介紹。

posted on 2012-02-26 16:07 yx 閱讀(3403) 評論(8)  編輯 收藏 引用 所屬分類: 隨機算法

評論

# re: 如何生成均勻隨機排列(等概率生成排列) 2012-02-26 20:39 driftfly

rand本身不是隨機  回復  更多評論   

# re: 如何生成均勻隨機排列(等概率生成排列) 2012-02-26 21:45 遠行

這個算法本身就是建立在它是隨機基礎上的,偽代碼里面那個Randomize,當然實現的時候也假設了rand()是隨機的了,至于它的隨機程度就不考慮了,你也可以采用更好的生成隨機數的接口@driftfly
  回復  更多評論   

# re: 如何生成均勻隨機排列(等概率生成排列) 2012-02-27 20:28 cmdblock

其實就是雙隨機而已,既隨機牌的大小又隨機位置。不過這種方法,個人覺得一般般啦  回復  更多評論   

# re: 如何生成均勻隨機排列(等概率生成排列) 2012-02-27 21:29 遠行

這個算法主要是可以證明等概率打亂排列@cmdblock
  回復  更多評論   

# re: 如何生成均勻隨機排列(等概率生成排列) 2012-08-10 10:12 peakflys

挺好的方法,無論是從空間上還是時間上 都是不錯的算法  回復  更多評論   

# re: 如何生成均勻隨機排列(等概率生成排列) 2012-10-16 12:25 liyonghelpme

有一種多項式生成排列的方式可以看看~~
http://en.wikipedia.org/wiki/Permutation_polynomial  回復  更多評論   

# re: 如何生成均勻隨機排列(等概率生成排列) 2013-10-09 10:15 justcyf

for (j = 0; j < i; ++j)

{

nArray[j] = j;

}

main函數里面的這段,第一行是不是寫錯了?應該為for(j = 0;j<20;++j)  回復  更多評論   

# re: 如何生成均勻隨機排列(等概率生成排列) 2013-10-09 10:17 justcyf

sorry,看錯了。。。@justcyf
  回復  更多評論   

<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導航

統計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學

網友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美激情欧美激情在线五月| 欧美一区二区三区另类| 巨乳诱惑日韩免费av| 欧美在线免费视屏| 狠狠色丁香久久婷婷综合丁香| 美女视频黄免费的久久| 欧美77777| 亚洲免费视频网站| 久久av一区二区三区漫画| 亚洲高清久久久| 日韩一区二区精品葵司在线| 久久久久久久网站| 一个人看的www久久| 在线综合亚洲欧美在线视频| 国产精品影院在线观看| 免费成人美女女| 欧美性天天影院| 欧美成人午夜| 国产精品xnxxcom| 免费亚洲电影| 国产精品久久久久久模特| 另类尿喷潮videofree| 欧美高潮视频| 久久精品二区| 欧美日韩精品免费在线观看视频 | 久久电影一区| 亚洲精选在线观看| 西瓜成人精品人成网站| 亚洲精品中文字幕女同| 校园春色国产精品| 亚洲视频一区| 另类欧美日韩国产在线| 午夜日本精品| 欧美片网站免费| 老司机精品久久| 亚洲永久精品国产| 亚洲免费黄色| 免费国产一区二区| 久久精品一区二区国产| 欧美日韩麻豆| 亚洲全黄一级网站| 国语自产精品视频在线看| 夜夜嗨一区二区| 亚洲精品国产精品乱码不99按摩| 午夜国产一区| 亚洲免费在线| 国产精品久久久久aaaa九色| 欧美激情 亚洲a∨综合| 加勒比av一区二区| 欧美一级视频一区二区| 亚洲天堂免费观看| 欧美日韩国产亚洲一区| 91久久中文| 亚洲激情国产精品| 久久亚洲综合色| 久久久久久久精| 狠狠色狠狠色综合人人| 久久大香伊蕉在人线观看热2| 欧美综合二区| 国产欧美一区二区三区在线看蜜臀 | 亚洲精品久久久久久一区二区 | 欧美女主播在线| 亚洲国产另类精品专区| 亚洲精品免费看| 欧美电影免费观看大全| 亚洲国产免费| 一本到12不卡视频在线dvd| 欧美国产亚洲精品久久久8v| 欧美成人高清视频| 亚洲国产精品一区二区三区| 久久免费99精品久久久久久| 美腿丝袜亚洲色图| 亚洲欧洲日韩在线| 欧美精品一区二| aaa亚洲精品一二三区| 亚洲欧美区自拍先锋| 国产日本欧美一区二区| 欧美一区综合| 蜜桃视频一区| 日韩亚洲欧美在线观看| 欧美三级日本三级少妇99| 亚洲色无码播放| 久久精品在线播放| 91久久夜色精品国产九色| 欧美精品 国产精品| 中国av一区| 麻豆精品精华液| 99视频精品在线| 国产精品一区二区久久精品| 久久riav二区三区| 亚洲激情电影在线| 欧美一区二区三区成人| 在线日本成人| 国产精品久久久久久久9999| 久久精品亚洲国产奇米99| 亚洲欧洲日本国产| 欧美在线你懂的| 亚洲日本视频| 国产欧美一区二区三区视频| 亚洲黄色天堂| 午夜精品久久久久久久99水蜜桃| 影音先锋中文字幕一区| 欧美午夜在线视频| 久久久综合网| 亚洲视频香蕉人妖| 免费一区视频| 欧美一级成年大片在线观看| 亚洲国产美女精品久久久久∴| 国产精品久久久久久久久果冻传媒 | 亚洲国产欧美日韩| 在线视频欧美一区| 在线观看欧美激情| 国产精品扒开腿做爽爽爽视频 | 欧美成人在线免费观看| 亚洲欧美激情一区| 一区二区精品国产| 欧美激情在线观看| 蜜臀va亚洲va欧美va天堂| 亚洲欧美日本日韩| 日韩视频免费观看高清在线视频| 国外成人网址| 国产自产高清不卡| 国产欧美69| 国产精品爽黄69| 国产精品qvod| 欧美日韩在线一区| 欧美成人午夜77777| 久久久久欧美精品| 久久精品国产一区二区电影| 亚洲综合国产| 亚洲天堂av在线免费| 亚洲精品影院| 亚洲精品乱码久久久久久蜜桃91 | 欧美亚洲一区三区| 午夜在线a亚洲v天堂网2018| 在线视频欧美日韩| 亚洲一区二区精品| 一区二区三区国产在线| 一本久久a久久精品亚洲| 亚洲国产小视频| 亚洲国产福利在线| 最新国产の精品合集bt伙计| 亚洲电影观看| 亚洲国产日韩一级| 亚洲乱码视频| 在线亚洲伦理| 欧美一级淫片aaaaaaa视频| 校园春色综合网| 久久国产精品黑丝| 久热综合在线亚洲精品| 欧美gay视频| 亚洲精品久久久久久久久| 99香蕉国产精品偷在线观看| 一区二区三区视频在线播放| 一区二区欧美国产| 亚洲欧美国产高清va在线播| 亚洲欧美视频一区| 老司机午夜精品| 欧美人体xx| 国产日韩欧美不卡| 亚洲国产岛国毛片在线| 99热精品在线| 欧美在线亚洲| 亚洲国产专区校园欧美| av成人免费观看| 久久国产精品免费一区| 欧美激情综合色| 国产精品一区二区久久精品| 在线不卡a资源高清| 亚洲伦伦在线| 精品99一区二区| 一本色道久久综合狠狠躁篇的优点| 亚洲天堂久久| 欧美xart系列高清| 一区二区久久久久| 麻豆freexxxx性91精品| 欧美日一区二区在线观看| 黑人极品videos精品欧美裸| 亚洲人永久免费| 久久精品欧洲| 一区二区欧美视频| 看欧美日韩国产| 国产精品一区视频| 亚洲日本视频| 久久综合九色综合欧美就去吻 | 亚洲一区欧美| 欧美电影免费| 精品成人一区| 欧美一区免费视频| 亚洲精品三级| 老司机一区二区三区| 国产无一区二区| 亚洲网站在线播放| 欧美激情五月| 久久久久久久久久久久久久一区 | 艳妇臀荡乳欲伦亚洲一区| 久久这里只精品最新地址| 99精品国产在热久久婷婷| 欧美国产另类| 亚洲欧洲视频在线|