Maison > Article > développement back-end > Comment implémenter des nombres aléatoires non répétitifs en php
Comment implémenter des nombres aléatoires non répétitifs en PHP : initialisez d'abord la variable à 0 ; puis créez un nouveau tableau ; puis générez aléatoirement un nombre dans une certaine plage et placez-le dans le tableau, puis supprimez les valeurs en double ; dans le tableau;Enfin, donnez simplement un nouveau nom de clé au tableau.
Recommandé : "Tutoriel vidéo PHP"
/* * array unique_rand( int $min, int $max, int $num ) * 生成一定数量的不重复随机数 * $min 和 $max: 指定随机数的范围 * $num: 指定生成数量 */ function unique_rand($min, $max, $num) { //初始化变量为0 $count = 0; //建一个新数组 $return = array(); while ($count < $num) { //在一定范围内随机生成一个数放入数组中 $return[] = mt_rand($min, $max); //去除数组中的重复值用了“翻翻法”,就是用array_flip()把数组的key和value交换两次。这种做法比用 array_unique() 快得多。 $return = array_flip(array_flip($return)); //将数组的数量存入变量count中 $count = count($return); } //为数组赋予新的键名 shuffle($return); return $return; }
Cette méthode obtient à chaque fois des nombres aléatoires et les stocke dans un tableau avant de les dédupliquer... Inefficace... Je ne veux pas utiliser
Remarque : cela est également mentionné dans le livre "Programming Pearls", intitulé "Comment générer efficacement m nombres aléatoires non répétitifs dans la plage de n (m<=n)"
Cet algorithme est très intelligent pour prendre la position du nombre aléatoire (<code style='padding: 2px 4px; margin: 0px 0px 8px; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; overflow-wrap: break-word; white-space: nowrap; font-size: 13px;'><span style="color:#ff6820; background-color:rgb(252,245,239)">数组的下标</span>
L'indice du tableau), au lieu de prendre le nombre aléatoire lui-même. Chaque fois qu'un nombre aléatoire est pris, il sera exclu de la plage de valeurs. La prochaine fois, ce sera uniquement Choisissez parmi les nombres restants, et la sélection de nombres aléatoires peut être effectuée en un seul parcours, ce qui est assez efficace.
function rand_num($num='200'){ for($i=0;$i<$num;$i++){ $n[$i] = $i; } for($i=0;$i<$num;$i++){ $rand = mt_rand($i,$num-1); //数组 随机数交换下标 if($n[$i] == $i){ $n[$i] = $n[$rand]; $n[$rand] = $i; } } }1. La première étape consiste à attribuer une valeur à chaque nombre du tableau dans l'ordre de son indice pour obtenir un $num number Les valeurs clés correspondent à un tableau de disposés dans l'ordre.
2. La deuxième étape commence à prendre le nombre aléatoire $rand dans la plage [i, $num-1], et obtiendra le nombre aléatoire $ rand est utilisé comme position actuelle dans le tableau clé i correspondant à la valeur de l'indice $rand, et le dans le tableau La valeur de $rand correspondant à l'indice est remplacée par i, qui est en fait le échange croisé de valeur de clé de tableau. Le sens est d'exclure de la plage de valeurs [ i,$num-1], la prochaine fois prendra la valeur parmi les nombres restants [ i+1,num-1 ]. 3. La troisième étape, afin d'éviter les valeurs répétées, effectuez uniquement des opérations alternées sur les paires clé-valeur inchangées, c'est-à-dire organiser le tableau d'origine dans l'ordre (clé == valeur) fonctionnent en alternance. 4. Fin. Organiser les tableaux dans l'ordreProcessus d'échange partiel Comme indiqué ci-dessus, obtenez 10 exemples partiels de nombres aléatoires.
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!