php 实现红包算法 给定总金额 总人数 最大金额 最小金额 生成红包列表
2018-05-14 11:20
190 查看
给定总积分,给定总人数,给定最大与最小值产生随机数/** * 功能:求一个数的平方 */public function _sqr($n){ return $n*$n;}
/** * 功能:生产min和max之间的随机数,但是概率不是平均的,从min到max方向概率逐渐减小。 * 先平方,然后产生一个平方值范围内的随机数,再开方,这样就产生了一种“膨胀”再“收缩”的效果。 * @param $point_max 每个小红包的最大额 * @param $point_min 每个小红包的最小额 */public function _xRandom($point_min,$point_max){ $sqr = intval($this->_sqr($point_max-$point_min)); $rand_num = rand(0, ($sqr-1)); return intval(sqrt($rand_num));}
/** * 功能:产生红包 * @param $total_point 红包总额 * @param $total_people 红包个数 * @param $point_max 每个小红包的最大额 * @param $point_min 每个小红包的最小额 * @return 存放生成的每个小红包的值的一维数组 */public function _getBonus($total_point, $total_people, $point_max, $point_min) { $result = array(); $average = $total_point / $total_people; if($point_max < $average){ for ($i = 0; $i < $total_people; $i++){ $result[$i] = 5; } return $result; }
for ($i = 0; $i < $total_people; $i++) { //因为小红包的数量通常是要比大红包的数量要多的,因为这里的概率要调换过来。 //当随机数>平均值,则产生小红包 //当随机数<平均值,则产生大红包 if (rand($point_min, $point_max) > $average) { // 在平均线上加积分 $temp = $point_min + $this->_xRandom($point_min, $average); $result[$i] = $temp; $total_point -= $temp; } else { // 在平均线上减钱 $temp = $point_max - $this->_xRandom($average, $point_max); $result[$i] = $temp; $total_point -= $temp; } } // 如果还有余积分,则尝试加到小红包里,如果加不进去,则尝试下一个。 while ($total_point > 0) { for ($i = 0; $i < $total_people; $i++) { if ($total_point > 0 && $result[$i] < $point_max) { $result[$i]++; $total_point--; } } } // 如果积分是负数了,还得从已生成的大于最小红包的红包中抽取回来 while ($total_point < 0) { for ($i = 0; $i < $total_people; $i++) { if ($total_point < 0 && $result[$i] > $point_min) { $result[$i]--; $total_point++; } } } return $result;} 阅读更多
/** * 功能:生产min和max之间的随机数,但是概率不是平均的,从min到max方向概率逐渐减小。 * 先平方,然后产生一个平方值范围内的随机数,再开方,这样就产生了一种“膨胀”再“收缩”的效果。 * @param $point_max 每个小红包的最大额 * @param $point_min 每个小红包的最小额 */public function _xRandom($point_min,$point_max){ $sqr = intval($this->_sqr($point_max-$point_min)); $rand_num = rand(0, ($sqr-1)); return intval(sqrt($rand_num));}
/** * 功能:产生红包 * @param $total_point 红包总额 * @param $total_people 红包个数 * @param $point_max 每个小红包的最大额 * @param $point_min 每个小红包的最小额 * @return 存放生成的每个小红包的值的一维数组 */public function _getBonus($total_point, $total_people, $point_max, $point_min) { $result = array(); $average = $total_point / $total_people; if($point_max < $average){ for ($i = 0; $i < $total_people; $i++){ $result[$i] = 5; } return $result; }
for ($i = 0; $i < $total_people; $i++) { //因为小红包的数量通常是要比大红包的数量要多的,因为这里的概率要调换过来。 //当随机数>平均值,则产生小红包 //当随机数<平均值,则产生大红包 if (rand($point_min, $point_max) > $average) { // 在平均线上加积分 $temp = $point_min + $this->_xRandom($point_min, $average); $result[$i] = $temp; $total_point -= $temp; } else { // 在平均线上减钱 $temp = $point_max - $this->_xRandom($average, $point_max); $result[$i] = $temp; $total_point -= $temp; } } // 如果还有余积分,则尝试加到小红包里,如果加不进去,则尝试下一个。 while ($total_point > 0) { for ($i = 0; $i < $total_people; $i++) { if ($total_point > 0 && $result[$i] < $point_max) { $result[$i]++; $total_point--; } } } // 如果积分是负数了,还得从已生成的大于最小红包的红包中抽取回来 while ($total_point < 0) { for ($i = 0; $i < $total_people; $i++) { if ($total_point < 0 && $result[$i] > $point_min) { $result[$i]--; $total_point++; } } } return $result;} 阅读更多
相关文章推荐
- PHP实现微信红包金额拆分试玩的算法示例
- PHP用抛物线的模型实现微信红包生成算法的程序源码
- 求一个数组中的最大值和最小值的算法改进 php 实现
- 微信随机生成红包金额算法php版
- 微信随机生成红包金额算法php版
- 一个php实现的生成排列的算法
- 数据结构(C#)--图结构的实现输出以及图结构的深度和广度优先搜索和Dijkstra 算法的最小路径以及最小生成树的实现
- 写出一个算法,对给定的n个数的序列,返回序列中的最大和最小的数
- 实用算法实现-第 19 第 最小生成树
- 【算法】堆,最大堆(大顶堆)及最小堆(小顶堆)的实现
- php递归实现无限分类生成下拉列表
- hdu 1233 还是畅通工程(最小生成树的Prim和Kruskal两种算法的c++实现)(prim算法详解)
- uva 11354最小生成树瓶颈路(lca算法实现)(rmq在多校二中有一道题)
- 遗传算法解决TSP问题实现以及与最小生成树的对比
- hdu 1233 还是畅通工程(最小生成树的Prim和Kruskal两种算法的c++实现)(prim算法详解)
- prim 最小生成树算法 java实现
- PHP实现加权随机数(Weighted Random sampling)的生成算法
- 【算法】堆,最大堆(大顶堆)及最小堆(小顶堆)的实现【2】---软件截图及算法代码
- prim 最小生成树算法 java实现
- 遗传算法解决TSP问题实现以及与最小生成树的对比