Maison > développement back-end > tutoriel php > Explication détaillée de l'algorithme d'enveloppe rouge aléatoire PHP

Explication détaillée de l'algorithme d'enveloppe rouge aléatoire PHP

墨辰丷
Libérer: 2023-03-26 16:42:02
original
1744 Les gens l'ont consulté

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;
}
Copier après la connexion
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 &#39;<pre class="brush:php;toolbar:false">&#39;; print_r($beans); echo array_sum($beans);
}
abc(100000, 3);
Copier après la connexion
Le quatrième type

 :

Parce que chaque personne a au moins 1 haricot, chaque fois que le nombre de haricots est généré aléatoirement, le nombre de personnes restant * 1 haricot doit être réservé

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 php

Algorithme

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal