Dalam bidang pengaturcaraan, situasi sering timbul di mana anda perlu menjana semua kemungkinan gabungan elemen daripada berbilang tatasusunan. Pertimbangkan senario berikut: anda memiliki tiga tatasusunan, dilambangkan sebagai $arrayA, $arrayB dan $arrayC, yang terdiri daripada elemen ['A1', 'A2', 'A3'], ['B1', 'B2', 'B3' ], dan ['C1', 'C2'], masing-masing. Objektif anda adalah untuk menjana tatasusunan yang mengandungi semua kemungkinan gabungan unsur-unsur ini.
Penyelesaian kepada cabaran ini terletak pada pendekatan rekursif. Fungsi combinations() mengambil tatasusunan tatasusunan sebagai inputnya dan parameter pilihan $i yang mewakili indeks semasa dalam tatasusunan. Apabila $i mencapai panjang tatasusunan, fungsi mengembalikan tatasusunan kosong, berfungsi sebagai kes asas untuk rekursi. Jika tidak, ia meneruskan untuk mengira gabungan daripada tatasusunan berikutnya, dilambangkan dengan $tmp.
Seterusnya, fungsi ini memulakan tatasusunan kosong $result dan berulang melalui tatasusunan semasa, diwakili oleh $arrays[$i]. Untuk setiap elemen $v dalam tatasusunan ini, fungsi menggelung melalui $tmp, menggabungkan setiap tatasusunan daripada $tmp dengan $v. Gabungan yang terhasil disimpan dalam tatasusunan $result.
Akhir sekali, fungsi mengembalikan tatasusunan $result, yang mengandungi semua kemungkinan gabungan elemen daripada tatasusunan input. Dengan menggunakan fungsi combinations() dengan tatasusunan yang sesuai, anda boleh menjana semua kombinasi yang diingini dengan cekap.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menjana Semua Kemungkinan Gabungan daripada Pelbagai Tatasusunan dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!