首页 > 编程语言 > 详细

红包算法

时间:2017-07-27 12:27:41      阅读:191      评论:0      收藏:0      [点我收藏+]
<?php
$r = redEnvelope(100, 10, 12, 6);
echo array_sum($r); //校验结果
print_r($r); //查看分布
 
function redEnvelope($sum, $num, $max, $min){
  $result = array_fill(0, $num, $min);
  $loop = $sum - $num * $min;
  $i = 0;
  while($loop) {
    $randNum = mt_rand(1, min($loop, $max - $min));
    if($randNum && $result[$i] + $randNum <= $max) {
      $result[$i] += $randNum;
      $loop -= $randNum;
    }
    $i = ($i + 1) % $num;
  } //分配结束
  //$max 至多出现一次
  $m = array_keys($result, max($result));
  if(count($m) > 1 && $result[$m[0]] == $max) {
    for($i=1; $i<count($m); $i++) {
      $n = array_keys($result, min($result));
      $result[$m[$i]]--;
      $result[$n[0]]++;
    }
  }
  //$min 至多出现一次
  $m = array_keys($result, min($result));
  if(count($m) > 1 && $result[$m[0]] == $min) {
    for($i=1; $i<count($m); $i++) {
      $n = array_keys($result, $min + 2);
      $result[$m[$i]]++;
      $result[$n[0]]--;
    }
  }
  return $result;
}

红包算法

原文:http://www.cnblogs.com/csjoz/p/7244076.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!