Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Sama ada tatasusunan mengandungi tatasusunan tertentu php

Sama ada tatasusunan mengandungi tatasusunan tertentu php

王林
王林asal
2023-05-07 19:20:35955semak imbas

Dalam PHP, kita boleh memanipulasi tatasusunan dalam pelbagai cara. Satu operasi yang berguna adalah untuk memeriksa sama ada tatasusunan mengandungi tatasusunan lain. Operasi ini boleh digunakan dalam banyak aplikasi, seperti semasa merentasi tatasusunan berbilang dimensi untuk mencari item tertentu atau semasa membuat permintaan dan respons menggunakan API RESTful.

Berikut akan memperkenalkan dua kaedah dalam PHP untuk menyemak sama ada tatasusunan mengandungi tatasusunan lain.

Kaedah 1: Gunakan fungsi in_array()

Fungsi in_array() boleh menentukan sama ada nilai berada dalam tatasusunan. Oleh itu, kita boleh membuat gelung melalui tatasusunan yang kami cari, dan kemudian gunakan fungsi in_array() untuk menentukan sama ada tatasusunan sasaran mengandungi tatasusunan ini. Berikut ialah contoh kod:

function checkArrayExists($needle, $haystack) {
    // 遍历 $needle 数组
    foreach ($needle as $value) {
        // 判断 $haystack 是否包含 $value
        if (!in_array($value, $haystack)) {
            return false;
        }
    }
    return true;
}

// 测试代码
$haystack = array('foo', 'bar', 'baz');
$needle1 = array('foo', 'baz');
$needle2 = array('foo', 'qux');

if (checkArrayExists($needle1, $haystack)) {
    echo 'needle1 is in haystack';
} else {
    echo 'needle1 is not in haystack';
}

if (checkArrayExists($needle2, $haystack)) {
    echo 'needle2 is in haystack';
} else {
    echo 'needle2 is not in haystack';
}

Kod di atas mentakrifkan fungsi yang dipanggil checkArrayExists() Dalam fungsi ini, kami menggunakan fungsi in_array() untuk menentukan sama ada nilai berada dalam tatasusunan sasaran, dan kemudian Kembalikan. hasil yang sesuai.

Perhatikan bahawa nilai dalam tatasusunan yang diperiksa mesti sepadan dengan tepat, termasuk jenis data.

Kaedah 2: Gunakan fungsi array_diff()

Dalam PHP, fungsi array_diff() boleh mengira perbezaan antara dua tatasusunan, iaitu mengembalikan nilai yang hanya muncul dalam satu tatasusunan. Jika perbezaan antara dua tatasusunan kosong, ini bermakna kedua-dua tatasusunan sepadan dengan tepat.

Oleh itu, kita boleh menukar kedua-dua tatasusunan untuk ditemui dan tatasusunan sasaran kepada set perbezaan, dan kemudian menentukan sama ada set perbezaannya kosong. Berikut ialah contoh kod:

function checkArrayExists($needle, $haystack) {
    $diff = array_diff($needle, $haystack);
    if (count($diff) == 0) {
        return true;
    }
    return false;
}

// 测试代码
$haystack = array('foo', 'bar', 'baz');
$needle1 = array('foo', 'baz');
$needle2 = array('foo', 'qux');

if (checkArrayExists($needle1, $haystack)) {
    echo 'needle1 is in haystack';
} else {
    echo 'needle1 is not in haystack';
}

if (checkArrayExists($needle2, $haystack)) {
    echo 'needle2 is in haystack';
} else {
    echo 'needle2 is not in haystack';
}

Kod di atas mentakrifkan fungsi yang dipanggil checkArrayExists() Dalam fungsi ini, kami menggunakan fungsi array_diff() untuk mengira perbezaan antara dua tatasusunan dan menentukan Semak sama ada set perbezaan). kosong, dan kemudian kembalikan hasil yang sepadan.

Kaedah yang manakah lebih baik?

Kedua-dua kaedah adalah cekap untuk menyemak sama ada tatasusunan mengandungi tatasusunan lain. Walau bagaimanapun, dari segi prestasi, kaedah 2 menggunakan fungsi array_diff() adalah lebih cekap, terutamanya apabila berurusan dengan tatasusunan yang besar. Oleh itu, kaedah dua harus digunakan untuk tatasusunan besar. Walau bagaimanapun, jika saiz tatasusunan agak kecil, kaedah 1 cukup baik, dan kodnya lebih ringkas dan jelas.

Ringkasnya, memahami kedua-dua kaedah ini membolehkan kami mengendalikan tatasusunan dengan lebih cekap dan meningkatkan kecekapan pengaturcaraan.

Atas ialah kandungan terperinci Sama ada tatasusunan mengandungi tatasusunan tertentu php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn