ホームページ  >  記事  >  バックエンド開発  >  PHPで実装されたレッドエンベロープ金額分割アルゴリズムのケースの詳細な説明

PHPで実装されたレッドエンベロープ金額分割アルゴリズムのケースの詳細な説明

php中世界最好的语言
php中世界最好的语言オリジナル
2018-05-17 10:51:031976ブラウズ

今回は、PHP での赤い封筒の金額分割アルゴリズムの実装の場合について詳しく説明します。 PHP での赤い封筒の金額分割アルゴリズムの実装の 注意点 は何ですか? 以下は実際的なケースです。一見。

<?php
// 新年红包金额拆分试玩
class CBonus
{
  public $bonus;//红包
  public $bonus_num;//红包个数
  public $bonus_money;//红包总金额
  public $money_single_max;//单个红包限额
  
  public function construct(){
    $this->bonus_num = 10;
    $this->bonus_money = 200;
    $this->money_single_max = 60;
  }
  private function randomFloat($min = 0, $max = 1) {
    $mt_rand = mt_rand();
    $mt_getrandmax = mt_getrandmax();
    echo &#39;mt_rand=&#39; . $mt_rand . &#39;, mt_getrandmax=&#39; . $mt_getrandmax . &#39;<hr/>&#39;;
    return $min + $mt_rand / $mt_getrandmax * ($max - $min);
  }
  //计算
  public function compute()
  {
    $this->bonus = array();
    $bonus_money_temp = $this->bonus_money;
    $money_single_max = $this->money_single_max;
    $i = 1;
    while($i < $this->bonus_num)
    {
      if ($money_single_max > $bonus_money_temp)
      {
        $money_single_max = floatval(sprintf("%01.2f", $bonus_money_temp / 2));//剩余金额不够分时,把剩余金额的一半作为备用金
      }
      $bonus_money_rad = $this->randomFloat(0.01, $money_single_max);//一个红包随机金额 最小的1分钱
      $bonus_money_rad = floatval(sprintf("%01.2f", $bonus_money_rad));
      $bonus_money_temp = $bonus_money_temp - $bonus_money_rad ;//待分配的总剩余金额
      $bonus_money_temp = floatval(sprintf("%01.2f", $bonus_money_temp));
      $this->bonus[] = $bonus_money_rad;
      //echo $bonus_money_rad . &#39;,&#39; . $bonus_money_temp . &#39;<hr/>&#39;;
      $i++;
    }
    $this->bonus[] = $bonus_money_temp;//分配剩余金额给最后一个红包
  }
  //打印
  public function output(){
    $total = 0;
    foreach($this->bonus as $k => $v)
    {
      echo &#39;红包&#39; . ($k+1) . &#39;=&#39; . $v . &#39;<br/>&#39;;
      $total += $v;
    }
    echo &#39;红包总金额:&#39;.$total;
  }
}
$CBonus = new CBonus();
$CBonus->compute();
$CBonus->output();
?>

デモ結果:

レッドパケット1=12.36
レッドパケット2=24.37
レッドパケット3=42.71
レッドパケット4=36.92
レッドパケット5=25.84
レッドパケット6=23.17
レッドパケット7 =15.92
赤い封筒 8= 1.35
赤い封筒 9=7.75
赤い封筒 10=9.61
赤い封筒の合計金額: 200

赤い封筒 1=24.59
赤い封筒 2=17.66
赤い封筒 3=29.67
赤い封筒 4=32.34
赤い封筒5=12.67
赤い封筒6=37.15
赤い封筒7=17.41
赤い封筒8=15.23
赤い封筒9=6.13
赤い封筒10=7.15
赤い封筒の合計金額:200

持っていると思いますこの記事の事例を読んでその方法をマスターしました。さらに興味深い情報については、PHP 中国語 Web サイトの他の関連記事に注目してください。

推奨読書:

PHPの依存関係逆転ケースの詳細な説明

PHPがファイルのMIMEタイプを取得する手順の詳細な説明

以上がPHPで実装されたレッドエンベロープ金額分割アルゴリズムのケースの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。