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

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

      這個算法的應用,比如洗牌,這個大家都非常熟悉。很久以前用的是最原始的方法,就是一直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 閱讀(3424) 評論(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
  回復  更多評論   


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2012年10月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

導航

統計

公告

常用鏈接

留言簿(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>
            久久久久久亚洲精品杨幂换脸| 久久综合精品国产一区二区三区| 欧美激情视频网站| 亚洲国产精品电影在线观看| 欧美大片国产精品| 欧美xart系列高清| 这里只有精品丝袜| 一区二区三区黄色| 国产免费观看久久| 免费成年人欧美视频| 欧美成人精品一区| 亚洲视频1区2区| 先锋影音国产精品| 亚洲国产成人精品女人久久久| 亚洲国产婷婷香蕉久久久久久| 欧美成人免费全部| 亚洲一区二区高清| 欧美一区二区| av成人天堂| 亚洲欧美大片| 亚洲高清在线观看| 日韩一级精品| 一区二区在线视频播放| 亚洲国产三级在线| 国产亚洲一区二区三区| 亚洲福利av| 国产亚洲成年网址在线观看| 亚洲第一精品福利| 国产区在线观看成人精品| 欧美.www| 国产精品尤物| 日韩天堂在线观看| 国一区二区在线观看| 亚洲理伦在线| 在线精品视频一区二区| 一区二区三区视频在线观看| ●精品国产综合乱码久久久久| av成人手机在线| 亚洲高清视频在线| 午夜精品国产精品大乳美女| 99精品国产福利在线观看免费| 欧美一区激情| 亚洲欧美日韩中文播放| 蜜臀久久久99精品久久久久久| 亚洲在线中文字幕| 欧美极品一区二区三区| 蜜桃av久久久亚洲精品| 国产精品色午夜在线观看| 亚洲二区精品| 亚洲国产另类久久久精品极度| 午夜国产精品视频| 亚洲在线视频免费观看| 欧美美女视频| 欧美激情在线狂野欧美精品| 国产综合香蕉五月婷在线| 亚洲性夜色噜噜噜7777| 一级日韩一区在线观看| 欧美黑人一区二区三区| 欧美国产一区视频在线观看 | 亚洲人成在线观看网站高清| 国产性做久久久久久| 亚洲一区二区在线免费观看视频 | 国产情侣久久| 亚洲专区在线视频| 亚洲欧美日韩国产中文| 欧美三区在线视频| 99国产精品国产精品久久| 日韩午夜av在线| 欧美国产一区二区在线观看| 亚洲福利视频一区二区| 日韩一级精品| 欧美精品一区二区在线观看 | 久久久青草婷婷精品综合日韩| 国产精品自在欧美一区| 亚洲综合丁香| 久久乐国产精品| 一区二区三区亚洲| 老色批av在线精品| 亚洲国产精品小视频| 99re热这里只有精品视频| 欧美日韩国产不卡| 一区二区三区国产| 久久精品一区二区三区中文字幕| 国产主播一区二区| 另类欧美日韩国产在线| 亚洲狼人综合| 欧美在线不卡| 亚洲第一黄色网| 欧美理论视频| 亚洲免费小视频| 鲁大师成人一区二区三区| 亚洲欧洲精品一区二区精品久久久| 免费成人网www| 在线中文字幕一区| 久久亚洲一区二区三区四区| 亚洲激情视频| 国产精品日韩精品欧美精品| 久久国产日韩| 亚洲国产一区二区a毛片| 亚洲男女自偷自拍| 狠狠色综合日日| 欧美另类videos死尸| 午夜欧美精品| 亚洲经典一区| 久久久www免费人成黑人精品| 亚洲区免费影片| 国产精品美女xx| 欧美福利网址| 亚洲欧美综合v| 亚洲欧洲免费视频| 久久爱91午夜羞羞| 久久蜜桃香蕉精品一区二区三区| 久久精品国产一区二区三区| 亚洲高清不卡在线观看| 欧美在线免费| 一本色道久久综合亚洲精品按摩| 国产欧美一区二区精品性色| 欧美高清视频一二三区| 午夜精品福利一区二区三区av| 亚洲成人在线视频网站| 久久免费高清视频| 亚洲中午字幕| 一本大道久久a久久精二百| 黑人巨大精品欧美黑白配亚洲| 国产精品成人v| 欧美激情一级片一区二区| 久久国产66| 亚洲欧美激情四射在线日| 亚洲人成在线观看| 免费成人在线观看视频| 久久久久高清| 久久www成人_看片免费不卡| 亚洲一区二区三区四区五区午夜| 亚洲欧洲精品一区二区| 亚洲电影自拍| 亚洲风情亚aⅴ在线发布| 国内精品久久久久久久果冻传媒| 国产精品系列在线| 欧美日韩一二区| 欧美日韩国产电影| 欧美二区在线| 欧美精品久久久久久久| 蜜桃视频一区| 欧美不卡一区| 欧美久久久久久| 欧美日韩午夜精品| 欧美午夜精品一区二区三区| 欧美日本国产视频| 欧美三级韩国三级日本三斤| 欧美日韩综合久久| 欧美日韩国产成人精品| 欧美色欧美亚洲另类二区| 欧美日韩精选| 国产精品久久久久久av福利软件| 国产精品超碰97尤物18| 国产精品视频精品| 国产一区视频在线看| 国内成人精品一区| 亚洲欧洲一区二区三区| 日韩视频免费观看高清在线视频 | 国产精品igao视频网网址不卡日韩| 欧美va亚洲va香蕉在线| 欧美福利视频| 欧美日韩成人网| 国产精品一区二区在线| 黄色另类av| 亚洲每日更新| 欧美亚洲系列| 女仆av观看一区| 亚洲毛片在线看| 午夜欧美大尺度福利影院在线看| 久久黄金**| 欧美精品一区二区三区蜜桃 | 欧美日韩国产成人在线91| 国产精品美女久久久免费| 激情综合久久| 亚洲一区bb| 蜜臀99久久精品久久久久久软件| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美大片免费观看| 欧美色精品天天在线观看视频| 国产日韩欧美制服另类| 91久久久一线二线三线品牌| 亚洲深夜福利| 蜜桃av一区二区| 亚洲午夜成aⅴ人片| 榴莲视频成人在线观看| 国产精品久久久久久久第一福利 | 欧美 日韩 国产在线| 国产精品久久久亚洲一区| 影音先锋另类| 亚洲欧美日韩系列| 亚洲成色777777女色窝| 午夜在线播放视频欧美| 欧美精品亚洲精品| 韩国视频理论视频久久| 亚洲综合电影| 最新国产精品拍自在线播放| 久久久www成人免费毛片麻豆| 国产精品高潮呻吟久久av无限|