本文主要介绍:使用 JS 根据奖品权重计算中奖概率实现抽奖的方法。

一、示例场景

1.1、设置抽奖活动的奖项名称

奖项名称:["一等奖", "二等奖", "三等奖", "未中奖"]。假设抽奖活动设置了这四个奖项,当然开发者可以扩展更多。

var prizes = ["一等奖","二等奖","三等奖","未中奖"]; //奖项名称数组

1.2、设置各奖项权重

奖项权重:[1, 5, 20, 74]。奖项权重主要用来表征各奖项的中奖几率,这里奖项权重数组的和值为100(=1+5+20+74),其中1表示一等奖的中奖概率为1%;5表示一等奖的中奖概率为5%;20表示三等奖的中奖概率为20%;最后剩下的74表示未中奖的概率为74%。

var prizeWeight = [1, 5, 20, 74]; //奖项权重数组,表征各奖项的中奖机会占总数的百分比。比如一等奖的中奖率是1%,二等奖的中奖率是5%

如果抽奖活动设置的奖项更多,开发者也可以相应扩展权重数组的和值,比如权重和值为500,1000等,并相应设置数组元素来表征每抽500次,可中多少次、什么等级的奖项。

另外,开发者也可以将奖项名称与奖项权重数组合并声明在一个对象中:

//设置奖项名称、权重等数组

var prizes =[

{"name": "一等奖", "weight": 1},

{"name": "二等奖", "weight": 5},

{"name": "三等奖", "weight": 20},

{"name": "未中奖", "weight": 74}

];

1.3、抽奖活动规则

0 < 本次抽奖随机数 <= 1,表示抽中一等奖;

1 < 本次抽奖随机数 <= 5,表示抽中二等奖;

5 < 本次抽奖随机数 <= 20,表示抽中三等奖;

本次抽奖随机数 > 20,表示未中奖。

二、实现原理

因为本文是简单实现,本抽奖程序的原理也设计得较为简单:

根据权重数组的和值(weightSum),在每次抽奖时生成一个权重随机数(weightRandom),这个权重随机数(weightRandom)是介于 0-weightSum (权重和值)之间的,本文示例设置的权重数组和值为100,表示生成的权重随机数是介于 0-100 之间的;

然后让这个权重随机数(weightRandom)去和权重数组中的所有元素值作比较,计算这个权重随机数(weightRandom)位于哪两个奖项之间,符合哪条中奖规则,对应哪个奖项名称。

比如:某次抽奖生成的权重随机数(weightRandom)为 15.15,按照 1.3 的活动规则,因为 5 <15.15 <= 20,表示此次生成的权重随机数(weightRandom)可中三等奖。

下面分别来实现:

2.1、计算权重和值

//数组累加求和函数:Array.reduce(function(prev ,cuurentValue), initialValue)

var weightSum = prizeWeight.reduce(function(prev, currVal){ //计算权重之和:1+5+20+74=100

return prev + currVal; //prev 是前一次累加后的数值,currVal 是本次待加的数值

}, 0);

2.2、编写抽奖函数(根据权重和值 weightSum,生成介于0-weightSum之间的权重随机数)

//抽奖函数

var lottery = function(weightSum) {var res = "未中奖"; //默认设置抽奖结果为“未中奖”

console.log("本程序的奖项权重和值:", weightSum);//生成一个权重随机数,介于0-weightSum之间

var random = Math.random()*weightSum; //生成一个权重随机数(0 到 weightSum 之间)

console.log("本次抽奖的权重随机数:", random);//权重数组重组并排序

var concatWeightArr = prizeWeight.concat(random); //将随机数加入权重数组

var sortedWeightArr = concatWeightArr.sort(function(a, b){return a-b;}); //将包含随机数的新权重数组按从小到大(升序)排序

console.log("含权重随机数的新权重数组升序排序后:", sortedWeightArr);//索引权重随机数的数组下标

var randomIndex = sortedWeightArr.indexOf(random); //索引随机数在新权重数组中的位置

randomIndex = Math.min(randomIndex, prizes.length -1); //权重随机数的下标不得超过奖项数组的长度-1,重新计算随机数在奖项数组中的索引位置

console.log("本次权重随机数对应的数组下标:", randomIndex);//取出对应奖项

res = prizes[randomIndex]; //从奖项数组中取出本次抽奖结果

console.log("本次抽奖结果:", res);return {"weightSum": weightSum , "weightRandom": random, prizeIndex: randomIndex, "data": res}; //返回本次抽奖结果

};

需要说明的是:

(1)在抽奖函数中,首先生成一个权重随机数(random),然后将这个权重随机数(random)与原权重数组合并(使用 Array.concat() 函数,返回值是一个新数组,原权重数组不变),生成一个新权重数组,并将新权重数组按照数值从小到大(升序)来排序(使用 Array.sort() 函数);这样,权重随机数(random)按照大小顺序,就会落在某两个奖项权重数值之间。最后索引权重随机数(random)在新权重数组中的下标,就可以取出对应的奖项名称数组中的元素。

(2)比如:某次抽奖函数生成的权重随机数为 15.15,与原来的权重数组:[1, 5, 20, 74] 合并,并排序,将得到新权重数组:[1, 5, 15.15,20, 74],权重随机数(15.15 )落在 5-20 之间,权重随机数(15.15)在新权重数组中的下标是 2,对应取出奖项名称数组下标为 2 的元素:prizes[2] = "三等奖"。由此判断本次抽奖可中三等奖。

(3)在抽奖函数中,为了确定权重随机数(random)的大小对应何种奖项时,即比较权重随机数与权重数组中各元素数值的大小时,编者没有使用传统的 for 循环来遍历比较权重随机数(random)与 prizeWeight 数组中各元素的大小,而是合并生成新的权重数组并排序,再使用 Array.indexOf() 函数来索引权重随机数(random)的下标,这个下标对应的奖项名称也就取出了。

三、最后将本示例项目的完整的代码与实现的效果展示出来

3.1、本示例项目JS部分核心代码:

//layui 模块化引用

layui.use(['jquery', 'util'], function(){var $ = layui.$, util =layui.util;//设置奖项名称、权重、中奖次数等数组

var prizes = ["一等奖", "二等奖", "三等奖", "未中奖"]; //奖项名称数组

var prizeWeight = [1, 5, 20, 74]; //奖项权重数组,表征各奖项的中奖机会占总数的百分比。比如一等奖的中奖率是1%,二等奖的中奖率是5%

//开发者也可合并声明奖项名称、权重等数组在一个对象中

//var prizes = [

//{"name": "一等奖", "weight": 1},

//{"name": "二等奖", "weight": 5},

//{"name": "三等奖", "weight": 20},

//{"name": "未中奖", "weight": 74}

//];

//数组累加求和函数:Array.reduce(function(prev ,cuurentValue), initialValue)

var weightSum = prizeWeight.reduce(function(prev, currVal){ //计算权重之和:1+5+20+74=100

return prev + currVal; //prev 是前一次累加后的数值,currVal 是本次待加的数值

}, 0);

document.getElementById("weightSum").innerHTML = weightSum; //设置权重和值

//抽奖函数

var lottery = function(weightSum) {var res = "未中奖"; //默认设置抽奖结果为“未中奖”

console.log("本程序的奖项权重和值:", weightSum);//生成一个权重随机数,介于0-weightSum之间

var random = Math.random()*weightSum; //生成一个权重随机数(0 到 weightSum 之间)

console.log("本次抽奖的权重随机数:", random);//权重数组重组并排序

var concatWeightArr = prizeWeight.concat(random); //将随机数加入权重数组

var sortedWeightArr = concatWeightArr.sort(function(a, b){return a-b;}); //将包含随机数的新权重数组按从小到大(升序)排序

console.log("含权重随机数的新权重数组升序排序后:", sortedWeightArr);//索引权重随机数的数组下标

var randomIndex = sortedWeightArr.indexOf(random); //索引随机数在新权重数组中的位置

randomIndex = Math.min(randomIndex, prizes.length -1); //权重随机数的下标不得超过奖项数组的长度-1,重新计算随机数在奖项数组中的索引位置

console.log("本次权重随机数对应的数组下标:", randomIndex);//取出对应奖项

res = prizes[randomIndex]; //从奖项数组中取出本次抽奖结果

console.log("本次抽奖结果:", res);return {"weightSum": weightSum , "weightRandom": random, prizeIndex: randomIndex, "data": res}; //返回本次抽奖结果

};//注册按钮事件

$('.layui-btn[data-type="save"]').on('click', function() {var res =lottery(weightSum);

document.getElementById("dateNow").innerHTML = util.toDateString(new Date()); //输出本次抽奖时间

document.getElementById("weightRandom").innerHTML = res.weightRandom; //输出本次抽奖的权重随机数

document.getElementById("printData").innerHTML = res.data; //输出本次抽奖结果

//重置中奖规则文字的字体颜色

$('.rule-body>p').css("color", "inherit");

$('.rule-body>p:eq(' + res.prizeIndex + ')').css("color", "red");

});

});

3.2:示例项目页面效果展示:

3.3、示例项目源码已上传至码云仓库

结束语

本文介绍的抽奖程序原理仅为 JS 简单实现,适用的场景十分有限,如果遇到需要设计更复杂的抽奖程序,也许开发者需要编写更为健壮、强大、公平、中奖次数可控的算法来实现抽奖函数。

java中奖率算法_JS简单实现:根据奖品权重计算中奖概率实现抽奖的方法相关推荐

  1. 【项目实战】——Java根据奖品权重计算中奖概率实现抽奖(适用于砸金蛋、大转盘等抽奖活动)...

    Java根据奖品权重计算中奖概率实现抽奖http://www.bieryun.com/1035.html 双蛋节(圣诞+元旦)刚刚过去,前几天项目上线的砸金蛋活动也圆满结束. 现在在许多网站上都会有抽 ...

  2. JS简单实现:根据奖品权重计算中奖概率实现抽奖的方法

    本文主要介绍:使用 JS 根据奖品权重计算中奖概率实现抽奖的方法. 一.示例场景 纯爱小说 www.shupu.org 1.1.设置抽奖活动的奖项名称 奖项名称:["一等奖", & ...

  3. html抽奖调整中奖率,JS简单实现:根据奖品权重计算中奖概率实现抽奖的方法 _ 惠州SEO...

    摘要 //layui模块化引用layui.use(['jquery','util'],function(){var$=layui.$,util=layui.util;//设置奖项名称.权重.中奖次数等 ...

  4. Java根据奖品权重计算中奖概率实现抽奖(适用于砸金蛋、大转盘等抽奖活动)

    ---------------------  作者:dannyhoo6688  来源:CSDN  原文:https://blog.csdn.net/huyuyang6688/article/detai ...

  5. 【项目实战】——Java根据奖品权重计算中奖概率实现抽奖(适用于砸金蛋、大转盘等抽奖活动)

    双蛋节(圣诞+元旦)刚刚过去,前几天项目上线的砸金蛋活动也圆满结束.   现在在许多网站上都会有抽奖的活动,抽奖的算法也是多种多样,这里介绍一下如何根据每种奖品的权重来抽奖,适用于多种抽奖形式. 奖品 ...

  6. java中奖率算法_抽奖概率-三种算法

    一.逢"几"中奖 逢"几"中奖,即通过预估抽奖人数和奖品数来判断,"几"=(抽奖人数/奖品数)*N.这是一种最简单抽奖算法,适合抽奖人数众多 ...

  7. JAVA数据结构与算法【简单介绍】

    前几天去面一个大厂,面试官特别好,面试官说到,我们的学习不能本末倒置,数据结构和算法是程序的基础,如果数据结构你没有学好,你真正意义上不算会写代码.你的代码是各处粘贴,杂乱无章的. 由于现在大多用JA ...

  8. java中奖率算法_Java抽奖概率算法

    序号 奖品名称 奖品编号 抽到的概率 1 再来一次 P1 0.2 2 本站VIP一年 P2 0.1 3 谢谢参与 P3 0.4 4 50金币 P4 0.3 5 Iphone 6 P5 0.0 6 Ip ...

  9. Java数据结构与算法(二) 简单排序

    #####1.冒泡排序 冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重 ...

最新文章

  1. debian var目录
  2. [SCOI2010]股票交易
  3. 第六课:不要为金钱而工作
  4. 操作 神通数据库_国产数据库最好的时代
  5. dateframe取某列数据_Python获取时序数据并进行可视化分析
  6. 全排列及相关扩展算法(三)——利用中介数求排列在字典序排位算法
  7. 成功在家用ssh远程连上了学校电脑虚拟机当中的ubuntu(代价是虚拟机全部黑屏只能用SSH连接了!)
  8. 思想一碰就冒火: 开源贡献须耐心, 选择框架要谨慎
  9. (0.2.2)如何下载mysql数据库(二进制、RPM、源码、YUM源)
  10. 数学图形(2.1)三叶结
  11. python 主线程_Python 主线程捕获子线程异常
  12. 为何AI也学会了种族和性别歧视?
  13. 全网独家:LINUX登录桌面后,如何自动运行自己的应用程序
  14. 2017电子设计大赛论文:滚球控制系统
  15. 利用C语言写一个等额本息的还款计算器。
  16. 搭档之家:李佳琦“双11”直播最低价,还是贵了?
  17. 计算机英语(编程词汇大全)
  18. CVPR21小样本检测:蒸馏上下文助力小样本检测(代码已开源)
  19. 为什么计算机不显示桌面工具栏,word菜单栏不见了-电脑任务栏显示桌面图标不见了怎么办...
  20. STM32_3 时钟初始化分析

热门文章

  1. Anki和欧陆词典的搭配使用
  2. 10个jQuery HTML5音频播放器
  3. linux lcd显示大数字,wm命令用法及LCD显示图标大小不正常时解决的方法
  4. 凸优化学习笔记 11:对偶原理 拉格朗日函数
  5. webpack自定义loader--编译.tpl文件
  6. H264编码profile level控制
  7. word如何制作三线表
  8. outlook 2007数据文件
  9. rhce redhat linux认证学习指南,RHCSA/RHCE 红帽Linux认证学习指南(第7版) EX200 EX300
  10. SpringBoot入门-分组校验