更多>
最新下载
24小时阅读排行榜
- 1 CSS绝对定位脱离文档流_对父容器高度及同级元素的影响
- 2 C++怎么实现单调栈_C++解决直方图最大矩形【算法】
- 3 C++怎么使用noexcept_C++异常规范教程【稳定】
- 4 如何通过代码为 WooCommerce 商品批量设置主图与图库图片
- 5 如何实现 Bootstrap 选项卡点击切换时自动隐藏其他内容
- 6 CSS加载失败的容错处理_如何设置备用样式路径
- 7 Linux启动失败怎么排查_启动日志分析完整流程
- 8 CSS如何利用Bootstrap的Flexbox工具类精细控制布局_快速调整css对齐
- 9 CSS如何处理定位元素在横屏模式下的布局重排_通过media查询重置css定位
- 10 C++ 怎么用scanf输入int C++ 格式化输入int教程【指南】
- 11 C++怎么求最大公约数 C++中gcd函数使用方法【技巧】
- 12 C++中的内联变量(inline variables)是什么?(如何解决重复定义)
- 13 HTML 输入框中显示序数词(如 1st、2nd)的实现方案
- 14 C++如何使用std::result_of推导函数调用返回类型?(C++17前替代invoke_result)
- 15 CSS浮动中的Clearfix性能优化_减少不必要的伪元素生成
更多>
最新教程
-
- Node.js 教程
- 17956 2025-08-28
-
- CSS3 教程
- 1552014 2025-08-27
-
- Rust 教程
- 25030 2025-08-27
-
- Vue 教程
- 26916 2025-08-22
-
- PostgreSQL 教程
- 23325 2025-08-21
-
- Git 教程
- 10189 2025-08-21
下载首页 / 类库下载 / 其它类库
<?php
function get_rand($proArr) {
$result = '';
//概率数组的总概率精度
$proSum = array_sum($proArr);
//概率数组循环
foreach ($proArr as $key => $proCur) {
$randNum = mt_rand(1, $proSum);
if ($randNum <= $proCur) {
$result = $key;
break;
} else {
$proSum -= $proCur;
}
}
unset ($proArr);
return $result;
}奖项数组是一个二维数组,记录了所有本次抽奖的奖项信息,其中id表示中奖等级,prize表示奖品,v表示中奖概率。注意其中的v必须为整数,你可以将对应的 奖项的v设置成0,即意味着该奖项抽中的几率是0,数组中v的总和(基数),基数越大越能体现概率的准确性。本例中v的总和为100,那么平板电脑对应的 中奖概率就是1%,如果v的总和是10000,那中奖概率就是万分之一了。$proArr是一个预先设置的数组,假设数组为:array(100,200,300,400),开始是从1,1000 这个概率范围内筛选第一个数是否在他的出现概率范围之内,如果不在,则将概率空间,也就是k的值减去刚刚的那个数字的概率空间,在本例当中就是减去100,也就是说第二个数是在1,900这个范围内筛选的。这样 筛选到最终,总会有一个数满足要求。就相当于去一个箱子里摸东西,第一个不是,第二个不是,第三个还不是,那最后一个一定是。这个算法简单,而且效率非常 高,关键是这个算法已在我们以前的项目中有应用,尤其是大数据量的项目中效率非常棒。
本站所有资源都是由网友投搞发布,或转载各大下载站,请自行检测软件的完整性!本站所有资源仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您自己承担!如有侵权请联系我们删除下架,联系方式:admin@php.cn
