この記事では、主に PHP で実装された WeChat 赤い封筒アルゴリズムを紹介し、例の形で関連する幸運な赤い封筒のランダム アルゴリズム技術を分析します。お役に立てれば幸いです。
詳細は次のとおりです:
最近、WeChatグループで赤い封筒機能を体験しています:
1.普通の赤い封筒
2.通常の赤い封筒を分析する必要はありません。大釜のご飯は均等に分割されます。
幸運の赤い封筒は、たくさん掴める人もいるし、残念ながら少ししか掴めない人もいます。最終的にはランダムです。
似たような機能(あえてアルゴリズムとは言いませんが)を実現できないか自分で考えて書きました。
// $bonus_total 红包总金额 // $bonus_count 红包个数 // $bonus_type 红包类型 1=拼手气红包 0=普通红包 function randBonus($bonus_total=0, $bonus_count=3, $bonus_type=1){ $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?(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はDiffie-Hellman鍵交換(Diffie-Hellman)アルゴリズムを実装しています
PHPで生成された迷路と自動経路探索アルゴリズムの詳細な説明
以上がPHPで実装されたランダムな赤い封筒アルゴリズムの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。