Rand.php 1.5 KB

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