Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk menentukan sama ada tatasusunan terkandung dalam tatasusunan lain dalam php

Bagaimana untuk menentukan sama ada tatasusunan terkandung dalam tatasusunan lain dalam php

Apr 24, 2023 pm 02:50 PM

Dalam pembangunan PHP, kita selalunya perlu menentukan sama ada tatasusunan terkandung dalam tatasusunan lain. Keadaan ini sangat biasa dalam kedua-dua pemprosesan data dan pemprosesan logik. Artikel ini akan memperkenalkan beberapa kaedah supaya pembangun boleh memilih cara yang paling sesuai untuk menentukan sama ada tatasusunan terkandung dalam tatasusunan lain berdasarkan situasi sebenar.

Kaedah 1: Gunakan fungsi array_diff

Fungsi array_diff ialah fungsi terbina dalam PHP yang membandingkan dua tatasusunan dan mengembalikan perbezaannya. Kerana hanya set perbezaan dikembalikan, kita boleh menentukan sama ada satu tatasusunan terkandung dalam tatasusunan lain dengan menentukan sama ada set perbezaan itu ialah tatasusunan kosong. Berikut ialah contoh kod:

$array1 = [1, 2, 3, 4, 5];
$array2 = [1, 2, 3];

// 比较两个数组并返回差集
$diff = array_diff($array2, $array1);

if (empty($diff)) {
    echo "array2 包含于 array1 中";
} else {
    echo "array2 不包含于 array1 中";
}
Salin selepas log masuk

Dalam kod di atas, dua tatasusunan $array1 dan $array2 pertama kali ditakrifkan $array2 ialah subset yang terkandung dalam $array1. Kemudian gunakan fungsi array_diff untuk mengira set perbezaan, dan gunakan fungsi kosong untuk menentukan sama ada set perbezaan adalah tatasusunan kosong, dan akhirnya mengeluarkan hasilnya.

Kaedah 2: Gunakan fungsi array_intersect

Serupa dengan fungsi array_diff, fungsi array_intersect juga merupakan fungsi terbina dalam PHP, digunakan untuk membandingkan dua tatasusunan dan mengembalikan persimpangan. Perbezaannya ialah array_intersect mengembalikan persimpangan, yang boleh menentukan sama ada tatasusunan terkandung oleh tatasusunan lain. Berikut ialah contoh kod:

$array1 = [1, 2, 3, 4, 5];
$array2 = [1, 2, 3];

// 比较两个数组并返回交集
$intersect = array_intersect($array2, $array1);

if ($intersect == $array2) {
    echo "array2 包含于 array1 中";
} else {
    echo "array2 不包含于 array1 中";
}
Salin selepas log masuk

Dalam kod di atas, dua tatasusunan $array1 dan $array2 pertama kali ditakrifkan $array2 ialah subset yang terkandung dalam $array1. Kemudian gunakan fungsi array_intersect untuk mengira persilangan, dan dengan menilai sama ada persimpangan itu sama dengan $array2, hasil akhir ialah output.

Kaedah 3: Gunakan fungsi in_array

Fungsi in_array ialah fungsi terbina dalam dalam PHP, digunakan untuk menyemak sama ada nilai wujud dalam tatasusunan. Kita boleh menyemak sama ada setiap elemen dalam tatasusunan $array2 wujud dalam $array1. Jika setiap elemen terdapat dalam $array1, maka $array2 boleh dikatakan sebagai subset $array1. Berikut ialah contoh kod:

$array1 = [1, 2, 3, 4, 5];
$array2 = [1, 2, 3];

$flag = true;

// 检查 $array2 中的每个元素是否存在于 $array1 中
foreach ($array2 as $value) {
    if (!in_array($value, $array1)) {
        $flag = false;
        break;
    }
}

if ($flag) {
    echo "array2 包含于 array1 中";
} else {
    echo "array2 不包含于 array1 中";
}
Salin selepas log masuk

Dalam kod di atas, dua tatasusunan $array1 dan $array2 pertama kali ditakrifkan $array2 ialah subset yang terkandung dalam $array1. Kemudian lelaran melalui setiap elemen dalam $array2 melalui foreach dan semak sama ada elemen itu wujud dalam $array1 menggunakan fungsi in_array. Jika setiap elemen wujud dalam $array1, $flag ditetapkan benar, jika tidak, ia ditetapkan palsu. Akhirnya, hasilnya adalah output berdasarkan nilai $flag.

Kaedah 4: Gunakan fungsi array_intersect_key

Fungsi array_intersect_key ialah fungsi terbina dalam PHP yang membandingkan kekunci dua tatasusunan dan mengembalikan persimpangan. Kita boleh menggunakan fungsi array_intersect_key untuk menentukan sama ada kunci satu tatasusunan semuanya wujud dalam tatasusunan lain. Jika ada, tatasusunan dianggap terkandung dalam tatasusunan lain. Berikut ialah contoh kod:

$array1 = ['a'=>1, 'b'=>2, 'c'=>3, 'd'=>4, 'e'=>5];
$array2 = ['a'=>1, 'b'=>2, 'c'=>3];

// 比较两个数组的键并返回交集
$intersect = array_intersect_key($array2, $array1);

if ($intersect == $array2) {
    echo "array2 包含于 array1 中";
} else {
    echo "array2 不包含于 array1 中";
}
Salin selepas log masuk

Dalam kod di atas, dua tatasusunan bersekutu $array1 dan $array2 pertama kali ditakrifkan $array2 ialah subset yang terkandung dalam $array1. Kemudian gunakan fungsi array_intersect_key untuk mengira persilangan kunci, dan tentukan sama ada persimpangan itu sama dengan $array2, dan akhirnya mengeluarkan hasilnya.

Ringkasan

Artikel ini memperkenalkan 4 kaedah untuk menentukan sama ada tatasusunan terkandung dalam tatasusunan lain. Antaranya, menggunakan fungsi array_diff dan fungsi array_intersect adalah kaedah yang lebih biasa dan mudah. Menggunakan fungsi in_array dan array_intersect_key adalah lebih tepat dan membolehkan anda menentukan kandungan array secara fleksibel.

Jika tatasusunan yang perlu dinilai adalah besar, adalah disyorkan untuk menggunakan dua kaedah yang terakhir, kerana fungsi array_diff dan array_intersect mungkin mempunyai kesan ke atas prestasi tatasusunan besar. Pada masa yang sama, pembangun juga boleh menggunakan kaedah ini secara menyeluruh berdasarkan keadaan sebenar untuk mencapai hasil yang terbaik.

Atas ialah kandungan terperinci Bagaimana untuk menentukan sama ada tatasusunan terkandung dalam tatasusunan lain dalam php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Mar 10, 2025 pm 06:15 PM

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Mar 10, 2025 pm 06:16 PM

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Bagaimana untuk menggunakan tugas-tugas asynchronous dalam PHP untuk operasi tidak menyekat? Bagaimana untuk menggunakan tugas-tugas asynchronous dalam PHP untuk operasi tidak menyekat? Mar 10, 2025 pm 04:21 PM

Artikel ini meneroka pelaksanaan tugas tak segerak dalam PHP untuk meningkatkan respons aplikasi web. Ia memperincikan kaedah seperti beratur mesej, rangka kerja asynchronous (reactphp, swoole), dan proses latar belakang, menekankan amalan terbaik untuk kecekapan

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Mar 10, 2025 pm 06:12 PM

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea

Bagaimana saya bekerja dengan sambungan php dan pecl? Bagaimana saya bekerja dengan sambungan php dan pecl? Mar 10, 2025 pm 06:12 PM

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

Bagaimana cara menggunakan teknik pengoptimuman memori dalam PHP? Bagaimana cara menggunakan teknik pengoptimuman memori dalam PHP? Mar 10, 2025 pm 04:23 PM

Artikel ini menangani pengoptimuman memori PHP. IT memperincikan teknik seperti menggunakan struktur data yang sesuai, mengelakkan penciptaan objek yang tidak perlu, dan menggunakan algoritma yang cekap. Sumber kebocoran memori biasa (mis., Sambungan yang tidak terkawal, global v

Bagaimanakah saya tetap up-to-date dengan ekosistem dan komuniti php? Bagaimanakah saya tetap up-to-date dengan ekosistem dan komuniti php? Mar 10, 2025 pm 06:16 PM

Artikel ini meneroka strategi untuk kekal semasa dalam ekosistem PHP. Ia menekankan penggunaan saluran rasmi, forum komuniti, persidangan, dan sumbangan sumber terbuka. Penulis menyoroti sumber terbaik untuk mempelajari ciri -ciri baru dan a

See all articles