生成加權(quán)隨機(jī)數(shù)我試圖設(shè)計(jì)一種(很好的)方法,從一個(gè)可能的數(shù)字范圍中選擇一個(gè)隨機(jī)數(shù),在這個(gè)范圍內(nèi)的每一個(gè)數(shù)都被賦予一個(gè)權(quán)重。簡(jiǎn)單地說(shuō):給定數(shù)字(0,1,2)的范圍,選擇一個(gè)0有80%的概率被選中的數(shù)字,1有10%的概率,2有10%的機(jī)會(huì)。我的大學(xué)統(tǒng)計(jì)課程已經(jīng)過(guò)去8年了,所以你可以想象一下,目前我還沒(méi)有找到合適的公式。這是我想出的“廉價(jià)和骯臟”的方法。此解決方案使用ColdFusion。你的語(yǔ)言可以用任何你喜歡的語(yǔ)言。我是個(gè)程序員,我想我能處理移植它。最終,我的解決方案需要使用Groovy-我是在ColdFusion中編寫的,因?yàn)樵贑F中快速編寫/測(cè)試很容易。public function weightedRandom( Struct options ) {
var tempArr = [];
for( var o in arguments.options )
{
var weight = arguments.options[ o ] * 10;
for ( var i = 1; i<= weight; i++ )
{
arrayAppend( tempArr, o );
}
}
return tempArr[ randRange( 1, arrayLen( tempArr ) ) ];}// test itopts = { 0=.8, 1=.1, 2=.1 };for( x = 1; x<=10; x++ ){
writeDump( weightedRandom( opts ) ); }我正在尋找更好的解決方案,請(qǐng)?zhí)岢龈倪M(jìn)或替代方案。
生成加權(quán)隨機(jī)數(shù)
繁星coding
2019-07-11 10:18:39