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

胖子依然6 2019-12-26 12:10:12 264 收藏
版权
本文主要介绍:使用 JS 根据奖品权重计算中奖概率实现抽奖的方法。

一、示例场景
纯爱小说 www.shupu.org
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=100return 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=100return 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.3、示例项目源码已上传至码云仓库

项目地址:https://gitee.com/kexin_front_end/js_lottery

演示地址:https://kexin_front_end.gitee.io/js_lottery/js_lottery.html

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

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

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

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

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

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

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

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

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

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

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

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

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

  7. 一个可以设置中奖概率的抽奖程序[转]

    一个可以设置中奖概率的抽奖程序[转] using System; using System.Collections.Generic; using System.Linq;namespace Conso ...

  8. php中奖概率算法程序,PHP中奖概率的抽奖算法程序代码

    PHP中奖概率的抽奖算法程序代码 //id为奖次,prize为中奖信息,v为中奖概率$prize_arr = array( '0' => array('id' => 1, 'prize' ...

  9. java 抽奖程序,自定义抽奖概率和奖品,模拟王者荣耀水晶抽奖

    一.定义奖品实体类 @Data @Builder public class LuckDrawRules {/*** id*/private Long id;/*** 奖品名称*/private Str ...

  10. PHP控制转盘抽奖代码,PHP 根据概率 实现抽奖转盘算法 代码

    最近实现大转盘功能涉及到抽奖概率的算法问题,整理了一下相关代码,欢迎大家参考哈~~~ 思路: 1. 录入中奖产品与中奖概率数据// 奖项id,奖品,概率 $prize_arr = array( '0' ...

最新文章

  1. iptables防火墙详解
  2. 重构机房VB.NET机房收费系统个人重构版你都学会了什么(之一)
  3. 三十四、多线程真的比单线程快?
  4. C# 对WinForm应用程序的App.config的使用及加密
  5. Exercise 12: Prompting People
  6. 【HDU - 2444】The Accomodation of Students(二分图判断 + 匈牙利算法求最大匹配)
  7. oracle用户被锁
  8. php自动include,PHP include_php
  9. 匈牙利算法 KM算法
  10. 远程服务器停止运行怎么回事,远程桌面连接已停止工作解决方法
  11. 【多字典公共键】快速找到多个字典的公共键及非公共键
  12. CAD梦想画图中删除命令
  13. 计算机在职研究生的详细介绍
  14. HTTP Header中的内容(请求Header、响应Header)
  15. OpenCV学习常用网址
  16. 测试软件cpu占用率 可以用,CPU占用率检测工具
  17. FXLMS主动降噪的simulink建模与仿真
  18. cocos2dx3.0戳青蛙游戏(打地鼠)
  19. 安徽航信研发项目管理体系探索与实践
  20. mysql 直接从date 文件夹备份表,还原数据库之后提示 table doesn`t exist的原因和解决方法

热门文章

  1. Java练习题之循环输出数字图形。例如1 22 333 4444 55555每输出一种数字换行。
  2. 太阳光轨迹软件_全球各地太阳全年日行路线图:呈8字曲线轨迹
  3. linux一句话精彩问答 (转贴)
  4. 怎样在视频上加字幕,分享视频添加字幕的小技巧
  5. 使用 Sublime 比较文档差异
  6. 物业公众号推文范例_如何运营社区物业微信公众号
  7. PS常用快捷键操作记录
  8. 计算机应用技术企业信息化,计算机应用技术对企业信息化作用
  9. canvas-八卦图和时钟实现
  10. 三维图看法亲身经验.