Mencipta Produk Cartesan Berbilang Tatasusunan dalam PHP
Pertimbangkan struktur tatasusunan PHP seperti berikut:
$array[0][0] = 'apples'; $array[0][1] = 'pears'; $array[0][2] = 'oranges'; $array[1][0] = 'steve'; $array[1][1] = 'bob';
Objektif: Untuk menjana senarai jadual semua kemungkinan gabungan elemen daripada tatasusunan ini, tanpa penduaan.
Penyelesaian:
Konsep menjana semua gabungan yang mungkin daripada berbilang tatasusunan dikenali sebagai "produk Cartesian." Terdapat beberapa kaedah untuk mencapai ini dalam PHP.
Satu pendekatan ialah menggunakan fungsi tatasusunan PHP. Coretan kod berikut melaksanakan produk Cartesian menggunakan func_get_args() dan rekursi:
function array_cartesian() { $_ = func_get_args(); if(count($_) == 0) return array(array()); $a = array_shift($_); $c = call_user_func_array(__FUNCTION__, $_); $r = array(); foreach($a as $v) foreach($c as $p) $r[] = array_merge(array($v), $p); return $r; }
Untuk menggunakan fungsi ini, hantarkan bilangan tatasusunan arbitrari sebagai argumen. Contohnya, untuk menjana produk Cartesian bagi tatasusunan di atas:
$cross = array_cartesian( array('apples', 'pears', 'oranges'), array('steve', 'bob') );
Hasilnya, disimpan dalam $cross, akan menjadi tatasusunan yang mengandungi semua kemungkinan kombinasi:
print_r($cross);
Output:
Array ( [0] => Array ( [0] => apples [1] => steve ) [1] => Array ( [0] => apples [1] => bob ) [2] => Array ( [0] => pears [1] => steve ) [3] => Array ( [0] => pears [1] => bob ) )
Atas ialah kandungan terperinci Bagaimana untuk Menghasilkan Produk Cartesian Berbilang Tatasusunan dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!