Bei der PHP-Programmierung stoßen wir häufig auf Szenarien, in denen wir die Reihenfolge von Array-Elementen ändern müssen, z. B. wenn wir eine Reihe von Zufallszahlen sortieren oder eine Reihe von Daten zufällig auswählen müssen. Im Allgemeinen können wir die mit PHP gelieferte Funktion shuffle() verwenden, um die Array-Elemente zu mischen. Diese Funktion ändert jedoch die Schlüsselwerte der Elemente, wodurch sich die Indizes der ursprünglichen Array-Reihenfolge ändern und dadurch das Original zerstört werden Datenstruktur. In diesem Artikel wird eine Methode zum Implementieren des PHP-Array-Shufflings vorgestellt, ohne die Reihenfolge der Array-Indizes zu ändern.
Methodenimplementierung
Um PHP-Array-Shuffling zu implementieren, ohne den Array-Reihenfolge-Index zu ändern, können wir eine dem Shuffling-Algorithmus ähnliche Methode verwenden, das heißt, alle Array-Elemente in ein neues Array kopieren und zufällig ein neues generieren. Sortierreihenfolge. Anschließend wird das ursprüngliche Array durchlaufen und seine Elemente nacheinander in der neuen Reihenfolge in das neue Array eingefügt. Auf diese Weise hat sich die tiefgestellte Reihenfolge des ursprünglichen Arrays nicht geändert, die Sortierreihenfolge der Array-Elemente wurde jedoch randomisiert. Der PHP-Code lautet wie folgt:
function shuffleArray($arr) {
// Array kopieren
$newArr = $arr;
// Nach dem Zufallsprinzip sortieren
shuffle($newArr);
// Das ursprüngliche Array durchlaufen
foreach ($arr as $key => $value) {
// 将元素按照新顺序填充到新数组中 $arr[$key] = $newArr[$key];
}
// Neues Array zurückgeben
return $arr;
}
Diese Funktion empfängt ein Eingabearray $arr und gibt ein neues Array in gemischter Reihenfolge zurück . In der Implementierung verwenden wir zunächst $newArr = $arr, um das ursprüngliche Array vollständig in das neue Array zu kopieren und mögliche Probleme durch Referenzen zu vermeiden. Als nächstes verwenden wir PHPs eigene shuffle()-Funktion, um das neue Array zufällig zu sortieren. Schließlich durchlaufen wir das ursprüngliche Array, füllen seine Elemente nacheinander in der neuen Reihenfolge in das neue Array und geben das neue Array zurück.
Vor- und Nachteile dieser Methode
Mit der oben genannten Methode kann ein PHP-Array-Shuffling erreicht werden, ohne die Reihenfolge der ursprünglichen Array-Indizes zu ändern:
Diese Methode weist jedoch auch die folgenden Mängel auf:
Zusammenfassung
Bei der PHP-Programmierung ist die Störung der Reihenfolge von Array-Elementen ein häufiges Anwendungsszenario. Die Verwendung der Funktion shuffle() ist eine einfache Möglichkeit, Arrays in PHP zu mischen. Diese Methode ändert jedoch die Reihenfolge der ursprünglichen Array-Indizes und zerstört so die ursprüngliche Array-Datenstruktur. Um das PHP-Array-Shuffling zu erreichen, ohne die tiefgestellte Reihenfolge des ursprünglichen Arrays zu zerstören, können wir eine dem Shuffling-Algorithmus ähnliche Methode verwenden. Diese Methode weist bestimmte Einschränkungen auf und kann das vorhandene Array nicht stören, bietet jedoch ein breites Anwendungsspektrum und einen präzisen und leicht verständlichen Code. Es handelt sich um einen praktischen Werkzeugalgorithmus in der PHP-Programmierung.
Das obige ist der detaillierte Inhalt vonWie man die Reihenfolge eines Arrays in PHP stört, aber die Indizes unverändert lässt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!