| 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;    }}
 |