Carian Rekursif untuk Pasangan Nilai Kunci dalam Tatasusunan PHP Berbilang Dimensi
Mencari pasangan nilai kunci tertentu dalam tatasusunan berbilang dimensi boleh menyusahkan. Jika kedalaman tatasusunan berubah-ubah, mencari penyelesaian yang pantas dan cekap adalah penting.
Fungsi Carian Rekursif
Fungsi PHP berikut menggunakan rekursi untuk melintasi tatasusunan secara rekursif, membandingkan nilai untuk kunci yang diberikan:
function search($array, $key, $value) { $results = array(); if (is_array($array)) { if (isset($array[$key]) && $array[$key] == $value) { $results[] = $array; } foreach ($array as $subarray) { $results = array_merge($results, search($subarray, $key, $value)); } } return $results; }
Contoh Penggunaan
Pertimbangkan tatasusunan sampel berikut:
$arr = array( 0 => array('id' => 1, 'name' => 'cat 1'), 1 => array('id' => 2, 'name' => 'cat 2'), 2 => array('id' => 3, 'name' => 'cat 1') );
Untuk mencari semua subarray dengan 'nama' kunci dan nilai 'kucing 1', kami gunakan:
print_r(search($arr, 'name', 'cat 1'));
Output:
Array ( [0] => Array ( [id] => 1 [name] => cat 1 ) [1] => Array ( [id] => 3 [name] => cat 1 ) )
Pertimbangan Kecekapan
Untuk kecekapan yang lebih baik, terutamanya untuk tatasusunan besar , pertimbangkan untuk menggunakan fungsi rekursif yang menghantar hasil melalui rujukan. Dengan berkongsi satu tatasusunan $results sementara, prestasi boleh dipertingkatkan dengan ketara:
function search_r($array, $key, $value, &$results) { if (!is_array($array)) { return; } if (isset($array[$key]) && $array[$key] == $value) { $results[] = $array; } foreach ($array as $subarray) { search_r($subarray, $key, $value, $results); } }
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencari Pasangan Nilai Kunci dengan Cekap dalam Tatasusunan PHP Berbilang Dimensi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!