


Dua cara untuk mengalih keluar data pendua daripada tatasusunan dalam PHP
Apabila melakukan pemprosesan data dalam PHP, kami sering menghadapi masalah seperti ini: terdapat tatasusunan yang menyimpan data, tetapi terdapat unsur pendua dalam tatasusunan dan unsur pendua perlu dialih keluar. Jadi bagaimana untuk menyelesaikan masalah ini?
Kaedah 1: Gunakan array_unique fungsi PHP sendiri
PHP menyediakan array_unique fungsi yang sangat mudah, yang boleh merealisasikan fungsi penyahduplikasi tatasusunan.
digunakan seperti berikut:
array array_unique ( array $array [, int $sort_flags = SORT_STRING ] )
di mana $array ialah tatasusunan yang perlu dinyahduplikasi, $sort_flags ialah parameter pilihan, menunjukkan kaedah pengisihan.
Prinsip fungsi ini ialah: mencipta tatasusunan kosong baharu, melintasi elemen dalam tatasusunan asal, jika elemen itu tidak wujud dalam tatasusunan baharu, tambahkan elemen itu kepada tatasusunan baharu.
Contohnya:
$arr = array(1, 2, 2, 3, 4, 4, 4, 5); $arr = array_unique($arr); print_r($arr);
Hasil output ialah:
Array ( [0] => 1 [1] => 2 [3] => 3 [4] => 4 [7] => 5 )
Seperti yang anda boleh lihat, elemen pendua dalam tatasusunan asal telah dialih keluar.
Kaedah 2: Melintasi tatasusunan
Selain menggunakan fungsi yang disertakan dengan PHP, anda juga boleh mencapai penyahduplikasian dengan melintasi tatasusunan.
Kaedah khusus ialah: cipta tatasusunan kosong baharu, lintasi elemen dalam tatasusunan asal, jika elemen itu tidak wujud dalam tatasusunan baharu, tambahkan elemen itu pada tatasusunan baharu.
Kod ini dilaksanakan seperti berikut:
$arr = array(1, 2, 2, 3, 4, 4, 4, 5); $new_arr = array(); // 新数组 foreach ($arr as $value) { if (!in_array($value, $new_arr)) { // $value 在 $new_arr 中不存在 $new_arr[] = $value; // 添加到 $new_arr 中 } } print_r($new_arr); // 输出新数组
Hasil output ialah:
Array ( [0] => 1 [1] => 2 [3] => 3 [4] => 4 [7] => 5 )
Berbanding dengan kaedah satu, kaedah ini agak menyusahkan, tetapi mengetahui prinsip asas ialah Memahami dalaman tatasusunan PHP adalah berguna.
Perlu diambil perhatian bahawa kecekapan kaedah dua adalah agak rendah, kerana ia perlu menentukan sama ada elemen itu wujud dalam tatasusunan baharu apabila merentasi Jika tatasusunan asal mempunyai lebih banyak elemen, masa berjalan mungkin lebih lama .
Ringkasnya, terdapat dua cara utama untuk menyahduplikasi tatasusunan PHP: menggunakan array_unique fungsi terbina dalam PHP dan merentasi tatasusunan kedua-dua kaedah boleh mencapai fungsi penyahduplikasian, antaranya menggunakan array_unique fungsi terbina dalam PHP lebih berkesan dan cepat.
Atas ialah kandungan terperinci Dua cara untuk mengalih keluar data pendua daripada tatasusunan dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Artikel ini meneroka deduplikasi array PHP yang cekap. Ia membandingkan fungsi terbina dalam seperti array_unique () dengan pendekatan hashmap tersuai, menonjolkan prestasi perdagangan berdasarkan saiz array dan jenis data. Kaedah optimum bergantung pada profili

Artikel ini meneroka deduplikasi PHP Array menggunakan keunikan utama. Walaupun bukan kaedah penyingkiran pendua langsung, memanfaatkan keunikan utama membolehkan membuat array baru dengan nilai yang unik dengan nilai pemetaan ke kekunci, menimpa duplikat. AP ini

Artikel ini menganalisis PHP Array Deduplication, menonjolkan kemunculan prestasi pendekatan naif (O (N²)). Ia meneroka alternatif yang cekap menggunakan array_unique () dengan fungsi tersuai, splobjectstorage, dan pelaksanaan hashset, mencapai

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

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

Artikel ini meneroka mengoptimumkan deduplikasi array PHP untuk dataset yang besar. Ia mengkaji teknik-teknik seperti array_unique (), array_flip (), splobjectstorage, dan pra-sorting, membandingkan kecekapan mereka. Untuk dataset besar -besaran, ia mencadangkan pemotongan, pangkalan data

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,

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
