PHP: Mendapatkan Semua Kemungkinan Gabungan Tatasusunan 1D
Pengenalan
Tugas untuk mendapatkan semula semua kemungkinan kombinasi elemen daripada tatasusunan 1D boleh ditemui dalam pelbagai aplikasi pengaturcaraan. Ia memerlukan pemahaman menyeluruh tentang pendekatan berulang atau rekursif untuk memperoleh semua pilih atur yang boleh dilaksanakan.
Pendekatan Berulang
Satu kaedah melibatkan penggunaan pendekatan berulang, seperti yang ditunjukkan dalam kod berikut :
<code class="php">function getCombinations($arr) { $result = array(); $count = count($arr); for ($i = 0; $i < (1 << $count); $i++) { $combination = array(); for ($j = 0; $j < $count; $j++) { if (($i & (1 << $j)) != 0) { $combination[] = $arr[$j]; } } $result[] = $combination; } return $result; } $array = array('Alpha', 'Beta', 'Gamma'); $combinations = getCombinations($array); print_r($combinations);
Output:
Array ( [0] => Array ( ) [1] => Array ( [0] => Alpha ) [2] => Array ( [0] => Beta ) [3] => Array ( [0] => Alpha [1] => Beta ) [4] => Array ( [0] => Gamma ) [5] => Array ( [0] => Alpha [1] => Gamma ) [6] => Array ( [0] => Beta [1] => Gamma ) [7] => Array ( [0] => Alpha [1] => Beta [2] => Gamma ) )</code>
Penjelasan:
Penyelesaian lelaran ini menggunakan manipulasi bit untuk menjana semua kombinasi yang mungkin. Dengan menambah nilai $i melalui semua nilai yang mungkin antara 0 dan (1 << $count) - 1, corak bit yang sepadan dengan setiap kombinasi diwujudkan. Menyemak sama ada bit tertentu dalam corak ini ditetapkan membenarkan penentuan elemen mana daripada tatasusunan input kepunyaan gabungan semasa.
Pendekatan Rekursif
Sebagai alternatif, rekursif pendekatan boleh digunakan untuk mencapai hasil yang sama:
<code class="php">function getCombinations($arr, $prefix = '') { $result = array(); foreach ($arr as $element) { $result[] = $prefix . $element; $result = array_merge($result, getCombinations($arr, $prefix . $element . ' ')); } return $result; } $array = array('Alpha', 'Beta', 'Gamma'); $combinations = getCombinations($array); print_r($combinations);
Output:
Array ( [0] => Alpha [1] => Alpha Beta [2] => Alpha Beta Gamma [3] => Alpha Gamma [4] => Alpha Gamma Beta [5] => Beta [6] => Beta Alpha [7] => Beta Alpha Gamma [8] => Beta Gamma [9] => Beta Gamma Alpha [10] => Gamma [11] => Gamma Alpha [12] => Gamma Alpha Beta [13] => Gamma Beta [14] => Gamma Beta Alpha )Penjelasan:
Penyelesaian rekursif ini menjana gabungan dengan menambah unsur berturut-turut pada awalan dan mengulangi elemen yang tinggal dalam tatasusunan. Kes asas berlaku apabila tatasusunan kosong, menghasilkan gabungan yang sah. Gabungan itu kemudiannya dikembalikan dalam susunan terbalik.
Dengan menggunakan sama ada pendekatan berulang atau rekursif, pembangun boleh mendapatkan semula semua kemungkinan gabungan elemen daripada tatasusunan 1D dengan berkesan, memenuhi keperluan pelbagai senario pengaturcaraan yang berbeza.
Atas ialah kandungan terperinci Bagaimana untuk Menjana Semua Kemungkinan Gabungan daripada Array 1D dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!