php抽奖概率怎么设计,php编写抽奖后台实现抽奖概率计算
下面提供两种抽奖中奖率计算的算法 ,第一种是自己设计出来的 ,第二种是比较经典的。 最重要的一点 概率学: 基数越大越能体现出中奖率。 比如扔10次硬币 5次正面和5次反面的概率比较小, 但是扔100次 1000次 10000次时 得到5正5反的结果越来越明显
方法一:
1 //奖品的集合列表
2 $prize_list = [
3 [
4 "id" => 1, //奖品的唯一标示
5 "name" => "奖品名称1", //奖品的名称
6 "img" => "upload/imgs/1578904174tR4llI.png", //奖品的图片
7 "pro" => 5, //奖品中奖的基数 这里的基数必须为正整数
8 "num" => 0, //奖品允许抽中的次数 0表示不限制
9 ],
10 [
11 "id" => 2,
12 "name" => "奖品名称2",
13 "img" => "upload/imgs/1578968755ie9uow.png",
14 "pro" => 5,
15 "num" => 0,
16 ]
17 ];
18 //计算奖品的概率问题(方法一) 假设我们所有奖品的中奖率设定为百分比,最小的中奖率是1%最大中奖率是100%
19 $arr = []; //根据奖品的中奖率生成一个中奖集合,集合越大,中奖率越准确
20 foreach ( $prize_list as $key => $vo ){
21 //如果中奖率小于1 将不会加入到中奖集合中(永远都不会被抽中)
22 if( $vo >= 1 ){
23 for( $i = 1 ; $i <= $vo['pro'] ; $i++ ){ //循环奖品设置的中奖率 ,
24 array_push( $arr ,$vo['id'] ); // 循环将奖品的id添加到中奖的集合中(如果商品A的中奖率为20,那么商品A的id就会咋中奖集合中重复20次)
25 }
26 }
27 }
28 //随机打算数组内中奖id的顺序
29 shuffle( $arr );
30 $lucky_index = array_rand( $arr , 1 ); //随机从中奖的集合中获取一个中奖的元素(这里返回的是当前元素所在的索引)
31 $lucky_id = $arr[$lucky_index]; //这里最终确定了抽中的奖品id
32 return $lucky_id;
方法二:
1 //奖品的集合列表
2 $prize_list = [
3 [
4 "id" => 1, //奖品的唯一标示
5 "name" => "奖品名称1", //奖品的名称
6 "img" => "upload/imgs/1578904174tR4llI.png", //奖品的图片
7 "pro" => 5, //奖品中奖的基数 这里的基数必须为正整数
8 "num" => 0, //奖品允许抽中的次数 0表示不限制
9 ],
10 [
11 "id" => 2,
12 "name" => "奖品名称2",
13 "img" => "upload/imgs/1578968755ie9uow.png",
14 "pro" => 5,
15 "num" => 0,
16 ]
17 ];
18 $arr_pro = []; //抽奖的集合 最总的结果在次数组的产生
19 foreach ( $prize_list as $key => $vo ){
20 $arr_pro[$vo['id']] = $vo['pro'];
21 }
22 //计算概率数组的总基数(基数越大 中奖率越准确)
23 $arr_num = array_sum( $arr_pro ); //将所有的中奖率累加起来得到一个基数
24 $lucky_id = '';
25 //概率数组循环27 foreach ($arr_pro as $key => $vv) {
28 $randNum = mt_rand(1, $arr_num);
29 if ($randNum <= $vv) {
30 $lucky_id = $key;
31 break;
32 } else {
33 $arr_num -= $vv;
34 }36 }
37 unset($arr_pro);
38 return $lucky_id;
标签:奖品,arr,抽奖,pro,num,中奖率,后台,php,id
来源: https://www.cnblogs.com/hinq/p/12195904.html
php抽奖概率怎么设计,php编写抽奖后台实现抽奖概率计算相关推荐
- 基于ASP.NET公益抽奖网站的设计与实现#毕业设计
经济发展使人民越来越富裕,人民的生活水平也越来越高,相对的人们的精神世界应该逐步提高,只有物质文明和精神文明两手一起抓,还能够让社会变得更加和谐,更加美好.于是就出现了很多的公益活动,如果单纯的进行公 ...
- 如何设计一个百万级用户的抽奖系统?
目录 1.抽奖系统的背景引入 2.结合具体业务需求分析抽奖系统 3.一个未经过优化的系统架构 4.负载均衡层的限流 5.Tomcat线程数量的优化 6.基于Redis实现抽奖业务逻辑 7.发放礼品环 ...
- (转载)如何设计一个百万级用户的抽奖系统?
1.抽奖系统的背景引入 本文给大家分享一个之前经历过的抽奖系统的流量削峰架构的设计方案. 抽奖.抢红包.秒杀,这类系统其实都有一些共同的特点,那就是在某个时间点会瞬间涌入大量的人来点击系统,给系统造成 ...
- java 抽奖程序,自定义抽奖概率和奖品,模拟王者荣耀水晶抽奖
一.定义奖品实体类 @Data @Builder public class LuckDrawRules {/*** id*/private Long id;/*** 奖品名称*/private Str ...
- mysql怎么设计抽奖表_Access设计抽奖系统
一.系统组成及原理 抽奖系统主要由来宾登记.奖票管理.幸运抽奖.获奖查询四个基本模块构成,登记模块登记参加抽奖人员,奖票管理模块初始化参加抽奖人员名单,抽奖模块实现抽奖功能,获奖查询模块查询获奖结果. ...
- 微信html抽奖转盘代码,使用CSS3+jquery.js 实现微信抽奖转盘效果
最近想起了刚接到这个项目时第一时间脑海里迸出的解决方法 "CSS3"! 为什么不能用CSS3来实现呢? 所以我打算用CSS3来实现这个效果.并不需要依赖jquery的动画效果插件, ...
- 原神服务器维护后抽奖池会更新吗,原神up池抽奖保底会在保留吗
1 回答 原神up池保底会保留到下次吗? 原神的保底机制是继承的,只能继承相同类型的卡池,不同类型的卡池继承互不干扰.常驻池只能继承[常驻池],UP池只能继承[UP池],新手卡池没有保底.比如,在温迪 ...
- 游戏抽奖网站用java怎么做,Java实现游戏抽奖算法
常用抽奖算法对比 基础的游戏抽奖算法通常要求实现在指定奖品的集合中,每个奖品根据对对应概率进行抽取.个人了解的主要有以下几中抽奖算法: 随机数一一对应 算法思想 这种算法思想最为简单.将n个奖品编号0 ...
- c语言中如何设计和编写一个应用系统?
C程序中,如何设计和编写一个应用系统? 一. C语言文件的操作 1. 文件操作的基本方法: C语言将计算机的输入输出设备都看作是文件.例如,键盘文件.屏幕文件等. 向屏幕输出一个信息,例如" ...
- MySQL学习笔记_6_SQL语言的设计与编写(下)
SQL语言的设计与编写(下) --SELECT查询精讲 概要: SELECT[ALL | DISTINCT] #distinct 明显的,清楚的,有区别的 {*|table.*|[table.]fie ...
最新文章
- 从疫情到求职寒冬,我的算法求职经历
- 什么是SAP FR?
- easyui datagrid 每行数据添加 按钮
- (笔试题)将数组分成两组,使两组的和的差的绝对值最小
- 如何构建GFS分布式存储平台?理论+实操!
- sqlserver2012分页注意事项
- NUMPY数据集练习 ----------SKLEARN类
- 【学习笔记】《Go 指南》
- 50. Pow(x, n)(递归,穷举)
- Exception in thread “main“ java.lang.UnsupportedOperationException Arrays.asList中add报错
- HDU 5491 The Next
- pycharm 运行后,如何查看变量值以及继续输入语句并运行?(非Debug , debug太慢)
- oracle dbms 存放位置,系统统计信息的保存位置
- 思科cisco2800系列路由器
- 算法——霍夫曼编码压缩算法
- yum 源没有php7.0,yum安装最新版php7的操作方法
- MNN推理引擎最新实测,CPU、GPU性能全面领先!
- HDUOJ1865 1string
- 基于LSB的信息隐藏
- 人工智能帮助千万用户完成「隐形征信」计算 1