Maison >développement back-end >tutoriel php >Explication détaillée de l'algorithme d'enveloppe rouge aléatoire PHP
Cet article présente principalement l'algorithme d'enveloppe rouge aléatoire implémenté en PHP, et analyse les principes, les méthodes de mise en œuvre et les précautions associées de l'algorithme d'enveloppe rouge aléatoire PHP sous forme d'exemples. Les amis dans le besoin peuvent se référer à ce qui suit
.comme suit :
1. Conception globale
Il existe de nombreux types d'algorithmes, vous pouvez choisir vous-même le principal ". architecture" est comme ça, utilisez la commande redis decr( ) pour limiter le courant, utilisez mysql pour enregistrer diverses données requises
2. Algorithme d'enveloppe rouge
Par souci de simplicité, le montant de l'enveloppe rouge est un nombre entier Expression, en supposant que chaque enveloppe rouge contient *2, Il faut pré-attribuer un grain à chaque personne au début
function randBean($total_bean, $total_packet) { $min_bean = 1; $max_bean = 5000; $range = 2; $total_bean = $total_bean - $total_packet * $min_bean; //每个人预留一个最小值 $list = []; $min = 1; while(count($list) < $total_packet){ $max = floor($total_bean / $total_packet) * $range; $bean = rand($min, $max); if ($bean <= $max_bean - 1) { $list[] = $bean; $total_bean -= $bean; } } $list[] = $total_bean;//剩余的金豆作为最后一个红包 //合并 foreach ($list as $k => $v) { $list[$k] += $min_bean; } return $list; }Statistiques multiples
Le deuxième type, pour simplement l'étendre , le montant maximum de chaque enveloppe rouge est de : (montant restant/nombre d'enveloppes rouges restantes)*3 mais il faut en envoyer au moins une à chaque fois 2 enveloppes rouges
La troisième méthode, méthode de segment de ligne, génère aléatoirement quelques nombres, divise une ligne droite en plusieurs segments, et la longueur de chaque segment (cette fluctuation est relativement grande, pas très moyenne, si Limiter la taille de chaque enveloppe rouge sera plus gênant )
function abc ($total_bean, $total_packet) { $min = 1; $max = $total_bean -1; $list = []; $maxLength = $total_packet - 1; while(count($list) < $maxLength) { $rand = mt_rand($min, $max); empty($list[$rand]) && ($list[$rand] = $rand); } $list[0] = 0; //第一个 $list[$total_bean] = $total_bean; //最后一个 sort($list); //不再保留索引 $beans = []; for ($j=1; $j<=$total_packet; $j++) { $beans[] = $list[$j] - $list[$j-1]; } // return $beans; echo '<pre class="brush:php;toolbar:false">'; print_r($beans); echo array_sum($beans); } abc(100000, 3);Le quatrième type
:
Après avoir supprimé ces numéros de haricots restants nécessaires, le nombre moyen de haricots restant est la valeur maximale ; pour générer aléatoirement le nombre de beans cette fois
Recommandations associées : Enveloppe rouge aléatoire implémentée par phpAlgorithme
Comment PHP implémente les enveloppes rouges fixes et les enveloppes rouges aléatoires
Explication détaillée de l'algorithme (photo)
php génère des paquets rouges aléatoires
un algorithme
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!