let buffer = [0,1,2,3,4]; // 獎池
let buff_probability = [0.2, 0.2, 0.2, 0.2, 0.2]; // 概率
randomProbability(buffer, buff_probability )
function randomProbability(arr1, arr2) {
var sum = 0,
factor = 0,
random = Math.random();
for(var i = arr2.length - 1; i >= 0; i--) {
sum += arr2[i]; // 統(tǒng)計概率總和
};
random *= sum; // 生成概率隨機數(shù)
for(var i = arr2.length - 1; i >= 0; i--) {
factor += arr2[i];
if(random <= factor) return arr1[i];
};
return null;
}
JS抽獎算法的一種實現(xiàn)
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。