Heim >Backend-Entwicklung >PHP-Tutorial >Wie kann ich in PHP alle möglichen Kombinationen aus einem 1D-Array generieren, einschließlich Kombinationen und Permutationen?
Alle möglichen Kombinationen in PHP abrufen: Eine umfassende Lösung
Das Abrufen aller möglichen Kombinationen aus einem 1D-Array kann eine komplexe Aufgabe sein, insbesondere wenn Dabei werden sowohl Kombinationen als auch Permutationen berücksichtigt. Obwohl es verschiedene Ansätze für dieses Problem gibt, besteht eine sehr effektive Lösung darin, eine rekursive Funktion zu implementieren.
Die rekursive Funktion Depth_picker() führt eine Tiefensuche im Array durch, durchsucht alle Zweige und kombiniert Elemente, um sie zu bilden Kombinationen. Es verwaltet eine temporäre Zeichenfolge, die mit jedem Element schrittweise geändert wird, während ein Sammelarray die endgültigen Kombinationen speichert. Sehen wir uns an, wie diese Funktion funktioniert:
Implementierung und Ausführung
Um diese Tiefensuche und den Abruf von Kombinationen zu implementieren, Der folgende PHP-Code kann verwendet werden:
<code class="php"><?php $array = array('Alpha', 'Beta', 'Gamma', 'Sigma'); function depth_picker($arr, $temp_string, &$collect) { if ($temp_string != "") $collect []= $temp_string; for ($i=0, $iMax = sizeof($arr); $i < $iMax; $i++) { $arrcopy = $arr; $elem = array_splice($arrcopy, $i, 1); // removes and returns the i'th element if (sizeof($arrcopy) > 0) { depth_picker($arrcopy, $temp_string ." " . $elem[0], $collect); } else { $collect []= $temp_string. " " . $elem[0]; } } } $collect = array(); depth_picker($array, "", $collect); print_r($collect); ?></code>
Bei der Ausführung gibt dieser Code das folgende Array aller möglichen Kombinationen und Anordnungen aus:
Array ( [0] => Alpha [1] => Alpha Beta [2] => Alpha Beta Gamma [3] => Alpha Beta Gamma Sigma [4] => Alpha Beta Sigma [5] => Alpha Beta Sigma Gamma [6] => Alpha Gamma [7] => Alpha Gamma Beta [8] => Alpha Gamma Beta Sigma [9] => Alpha Gamma Sigma [10] => Alpha Gamma Sigma Beta [11] => Alpha Sigma [12] => Alpha Sigma Beta [13] => Alpha Sigma Beta Gamma [14] => Alpha Sigma Gamma [15] => Alpha Sigma Gamma Beta [16] => Beta [17] => Beta Alpha [18] => Beta Alpha Gamma [19] => Beta Alpha Gamma Sigma [20] => Beta Alpha Sigma [21] => Beta Alpha Sigma Gamma [22] => Beta Gamma [23] => Beta Gamma Alpha [24] => Beta Gamma Alpha Sigma [25] => Beta Gamma Sigma [26] => Beta Gamma Sigma Alpha [27] => Beta Sigma [28] => Beta Sigma Alpha [29] => Beta Sigma Alpha Gamma [30] => Beta Sigma Gamma [31] => Beta Sigma Gamma Alpha [32] => Gamma [33] => Gamma Alpha [34] => Gamma Alpha Beta [35] => Gamma Alpha Beta Sigma [36] => Gamma Alpha Sigma [37] => Gamma Alpha Sigma Beta [38] => Gamma Beta [39] => Gamma Beta Alpha [40] => Gamma Beta Alpha Sigma [41] => Gamma Beta Sigma [42] => Gamma Beta Sigma Alpha [43] => Gamma Sigma [44] => Gamma Sigma Alpha [45] => Gamma Sigma Alpha Beta [46] => Gamma Sigma Beta [47] => Gamma Sigma Beta Alpha [48] => Sigma [49] => Sigma Alpha [50] => Sigma Alpha Beta [51] => Sigma Alpha Beta Gamma [52] => Sigma Alpha Gamma [53] => Sigma Alpha Gamma Beta [54] => Sigma Beta [55] => Sigma Beta Alpha [56] => Sigma Beta Alpha Gamma [57] => Sigma Beta Gamma [58] => Sigma Beta Gamma Alpha [59] => Sigma Gamma [60] => Sigma Gamma Alpha [61] => Sigma Gamma Alpha Beta [62] => Sigma Gamma Beta [63] => Sigma Gamma Beta Alpha )
Dieser Ansatz bietet eine umfassende und effiziente Lösung um alle möglichen Kombinationen von Elementen in einem Array zu erhalten und sicherzustellen, dass sowohl Kombinationen als auch unterschiedliche Anordnungen in der Ausgabe enthalten sind.
Das obige ist der detaillierte Inhalt vonWie kann ich in PHP alle möglichen Kombinationen aus einem 1D-Array generieren, einschließlich Kombinationen und Permutationen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!