Maison  >  Article  >  développement back-end  >  Comment perturber l'ordre des tableaux en php mais garder les indices inchangés

Comment perturber l'ordre des tableaux en php mais garder les indices inchangés

PHPz
PHPzoriginal
2023-04-27 15:37:34689parcourir

En programmation PHP, nous rencontrons souvent des scénarios dans lesquels nous devons perturber l'ordre des éléments d'un tableau, par exemple devoir trier un ensemble de nombres aléatoires ou échantillonner aléatoirement un ensemble de données. De manière générale, nous pouvons utiliser la fonction shuffle() fournie avec PHP pour mélanger les éléments du tableau, mais cette fonction modifiera les valeurs clés des éléments, provoquant la modification des indices de l'ordre du tableau d'origine, détruisant ainsi l'original. structure des données. Cet article présentera une méthode pour implémenter le brassage de tableaux PHP sans modifier l'ordre des indices du tableau.

Méthode d'implémentation

Afin d'implémenter le brassage de tableau PHP sans changer l'indice d'ordre du tableau, nous pouvons utiliser une méthode similaire à l'algorithme de brassage, c'est-à-dire copier tous les éléments du tableau dans un nouveau tableau et générer aléatoirement un nouvel ordre de tri. Parcourez ensuite le tableau d'origine et remplissez ses éléments dans le nouveau tableau un par un dans le nouvel ordre. De cette façon, l'ordre des indices du tableau d'origine n'a pas changé, mais l'ordre de tri des éléments du tableau a été randomisé. Le code PHP est le suivant :

function shuffleArray($arr) {
//Copier le tableau
$newArr = $arr;

// Tri aléatoire# 🎜🎜# shuffle($newArr);

// Parcourez le tableau d'origine

foreach ($arr as $key => $value) {

// 将元素按照新顺序填充到新数组中
$arr[$key] = $newArr[$key];
# 🎜🎜#}

// Renvoie un nouveau tableau

return $arr;

}

Cette fonction reçoit un tableau d'entrée $arr et renvoie un tableau mélangé, nouveau tableau. Dans l'implémentation, nous utilisons d'abord $newArr = $arr pour copier complètement le tableau d'origine dans le nouveau tableau afin d'éviter les problèmes potentiels causés par les références. Ensuite, nous utilisons la fonction shuffle() de PHP pour trier aléatoirement le nouveau tableau. Enfin, nous parcourons le tableau d'origine, remplissons ses éléments dans le nouveau tableau un par un dans le nouvel ordre et renvoyons le nouveau tableau.

Avantages et inconvénients de cette méthode

L'utilisation de la méthode ci-dessus peut réaliser un brassage de tableau PHP sans changer l'ordre des indices du tableau d'origine, ce qui présente les avantages suivants : #🎜🎜 ##🎜🎜 #

Grâce à la fonction shuffle() fournie avec PHP, le code est concis et facile à comprendre.

En copiant complètement le tableau d'origine vers le nouveau tableau, les problèmes potentiels causés par les références peuvent être évités et le code sera plus robuste.
  1. Il a un large éventail d'applications, sans tenir compte de la structure des données et du nombre d'éléments du tableau d'origine, et convient à tout type de tableau.
  2. Cependant, cette méthode présente également les inconvénients suivants :
Dans la mise en œuvre, un tableau supplémentaire doit être utilisé pour stocker la commande brouillée , qui ne peut pas mélanger le tableau en place.

Pour les grands tableaux, cette méthode est moins efficace et nécessite des opérations de parcours et de remplissage basées sur de l'espace supplémentaire. Si des quantités massives de données doivent être cryptées, il est recommandé d’utiliser des algorithmes plus efficaces.
  1. Pour les scénarios d'application qui doivent garantir un caractère aléatoire absolu (comme la génération de mot de passe), puisque la couche inférieure de la fonction shuffle() repose sur des appels de départ aléatoires, le caractère aléatoire absolu des données ne peut pas être garanti, et un algorithme de génération aléatoire plus sécurisé doit être utilisé.
  2. Summary
  3. En programmation PHP, perturber l'ordre des éléments d'un tableau est un scénario d'application courant. L'utilisation de la fonction shuffle() est un moyen simple de mélanger des tableaux en PHP, mais cette méthode modifiera l'ordre des indices du tableau d'origine, détruisant ainsi la structure de données du tableau d'origine. Afin de réaliser le brassage des tableaux PHP sans détruire l'ordre des indices du tableau d'origine, nous pouvons utiliser une méthode similaire à l'algorithme de brassage. Cette méthode présente certaines limites et ne peut pas perturber le tableau en place, mais elle a un large éventail d'applications et le code est concis et facile à comprendre. Il s'agit d'un algorithme d'outil pratique en programmation PHP.

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!

Déclaration:
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