123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- <?php
- /**
- * Rand.php UTF-8
- *
- *
- * @date : 2018/5/10 20:36
- *
- * @license 这不是一个自由软件,未经授权不许任何使用和传播。
- * @author : wuyonghong <wyh@huosdk.com>
- * @version : HUOSDK 8.0
- */
- namespace huolib\tool;
- class Rand {
- /*
- * 经典的概率算法,
- * $proArr是一个预先设置的数组,
- * 假设数组为:array(100,200,300,400),
- * 开始是从1,1000 这个概率范围内筛选第一个数是否在他的出现概率范围之内,
- * 如果不在,则将概率空间,也就是k的值减去刚刚的那个数字的概率空间,
- * 在本例当中就是减去100,也就是说第二个数是在1,900这个范围内筛选的。
- * 这样 筛选到最终,总会有一个数满足要求。
- * 就相当于去一个箱子里摸东西,
- * 第一个不是,第二个不是,第三个还不是,那最后一个一定是。
- * 这个算法简单,而且效率非常 高
- */
- public static function getRand($pre_arr) {
- $_result = '';
- //概率数组的总概率精度
- $_pre_sum = array_sum($pre_arr);
- //概率数组循环
- foreach ($pre_arr as $_key => $_pre_cur) {
- $_rand_num = mt_rand(1, $_pre_sum);
- if ($_rand_num <= $_pre_cur) {
- $_result = $_key;
- break;
- } else {
- $_pre_sum -= $_pre_cur;
- }
- }
- unset ($pre_arr);
- return $_result;
- }
- }
|