ホームページ > バックエンド開発 > PHPチュートリアル > PHP 乱数 WeChat 赤封筒ランダム生成アルゴリズム PHP バージョン

PHP 乱数 WeChat 赤封筒ランダム生成アルゴリズム PHP バージョン

WBOY
リリース: 2016-07-27 16:56:23
オリジナル
1612 人が閲覧しました

私はしばらく考えて、同様の機能を実現する WeChat 赤封筒ランダム生成アルゴリズムの PHP バージョンを作成できないか尋ねました (実際には、アルゴリズムとはあえて言いません)。
// $bonus_total 赤い封筒の総量
// $bonus_count 赤い封筒の数
// $bonus_type 赤い封筒の種類 1=幸運の赤い封筒 0=普通の赤い封筒

function randBonus($b $b $b
  $bonus_items  = array(); // 将要瓜分的结果
  $bonus_balance = $bonus_total; // 每次分完之后的余额
  $bonus_avg   = number_format($bonus_total/$bonus_count, 2); // 平均每个红包多少钱
  $i       = 0;
  while($i<$bonus_count){
    if($i<$bonus_count-1){
      $rand      = $bonus_type&#63;(rand(1, $bonus_balance*100-1)/100):$bonus_avg; // 根据红包类型计算当前红包的金额
      $bonus_items[] = $rand;
      $bonus_balance -= $rand;
    }else{
      $bonus_items[] = $bonus_balance; // 最后一个红包直接承包最后所有的金额,保证发出的总金额正确
    }
    $i++;
  }
  return $bonus_items;
}
ログイン後にコピー

それでは、今すぐ体験してみましょう

// 发3个拼手气红包,总金额是100元
$bonus_items  = randBonus(100, 3, 1);
// 查看生成的红包
var_dump($bonus_items);
// 校验总金额是不是正确,看看微信有没有坑我们的钱
var_dump(array_sum($bonus_items));
ログイン後にコピー

配列を使用して実装された別のバージョンも同様です:

function sendRandBonus($total=0, $count=3, $type=1){
  if($type==1){
    $input     = range(0.01, $total, 0.01);
    if($count>1){
      $rand_keys = (array) array_rand($input, $count-1);
      $last    = 0;
      foreach($rand_keys as $i=>$key){
        $current  = $input[$key]-$last;
        $items[]  = $current;
        $last    = $input[$key];
      }
    }
    $items[]    = $total-array_sum($items);
  }else{
    $avg      = number_format($total/$count, 2);
    $i       = 0;
    while($i<$count){
      $items[]  = $i<$count-1?$avg:($total-array_sum($items));
      $i++;
    }
  }
  return $items;
}
ログイン後にコピー

上記がこの記事の全内容です。皆さんの学習に役立つことを願っています。また、皆さんがこのサイトをサポートしてくれることを願っています。 。

上記では、PHP 乱数の内容を含む、PHP 乱数 WeChat 赤い封筒のランダム生成アルゴリズム PHP バージョンを紹介しました。PHP チュートリアルに興味のある友人に役立つことを願っています。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート