Rumah pembangunan bahagian belakang masalah PHP PHP melaksanakan algoritma penyahduplikasian tatasusunan

PHP melaksanakan algoritma penyahduplikasian tatasusunan

May 05, 2023 pm 08:04 PM

Dengan peningkatan berterusan pemprosesan data, penyahduplikasian data telah menjadi masalah biasa dalam banyak aplikasi. Dalam PHP, kita boleh menggunakan pelbagai algoritma untuk melaksanakan penyahduplikasian tatasusunan, seperti kaedah penyusunan deduplikasi tatasusunan, kaedah nilai kunci cincang, kaedah in_array, dll. Di bawah ini kami memperkenalkan secara terperinci kaedah melaksanakan algoritma penyahduplikasian tatasusunan dalam PHP.

1. Kaedah penyahduplikasian tatasusunan dan pengisihan

Kaedah penyahduplikasian tatasusunan dan pengisihan ialah kaedah penyahduplikasian yang agak biasa . Berikut ialah kod sampel yang menggunakan kaedah pengisihan deduplikasi tatasusunan untuk melaksanakan penyahduplikasian tatasusunan:

function array_unique_sort($array) {
    sort($array); // 将数组按照元素值排序
    $last = null; // 记录上一个元素值
    foreach ($array as $key => $value) {
        if ($value === $last) {
            unset($array[$key]); // 删除相邻的重复元素
            continue;
        }
        $last = $value;
    }
    return $array;
}
Salin selepas log masuk

Dalam kod di atas, kita mula-mula menggunakan fungsi sort() untuk mengisih tatasusunan. Kemudian, kami menggunakan gelung foreach untuk lelaran melalui setiap elemen dalam tatasusunan dan menggunakan pembolehubah $last untuk merekodkan nilai elemen sebelumnya. Apabila dua elemen bersebelahan mempunyai nilai yang sama, kami menggunakan fungsi unset() untuk memadam salah satu elemen. Akhirnya, tatasusunan penduaan dikembalikan.

2. Kaedah kunci cincang

Kaedah kunci cincang ialah satu lagi kaedah penyahduplikasi tatasusunan yang biasa digunakan untuk menyimpan unsur-unsur dalam tatasusunan elemen sebagai kunci cincang untuk menyimpan setiap elemen dalam tatasusunan di bawah kunci cincang yang sepadan. Jika nilai elemen yang sama berlaku, hanya satu disimpan, dan akhirnya tatasusunan sementara dikembalikan. Berikut ialah contoh kod yang menggunakan kaedah nilai kunci cincang untuk melaksanakan penyahduplikasi tatasusunan:

function array_unique_hash($array) {
    $temp = array(); // 临时数组
    foreach ($array as $value) {
        if (isset($temp[$value])) {
            continue; // 已经出现过的元素,跳过
        }
        $temp[$value] = $value; // 新元素,添加到临时数组中
    }
    return array_values($temp); // 返回去重后的数组
}
Salin selepas log masuk

Dalam kod di atas, kami menggunakan tatasusunan sementara $temp untuk menyimpan elemen pendua. Lintas setiap elemen dalam tatasusunan asal Jika elemen telah muncul, langkau ia jika tidak, tambahkan elemen pada tatasusunan sementara sebagai kunci dan nilai. Akhir sekali, kami mengembalikan hasil penduaan melalui fungsi array_values().

3. Kaedah in_array

Kaedah in_array ialah kaedah penyahduplikasian tatasusunan yang agak mudah tetapi tidak cekap elemen telah muncul dalam tatasusunan sementara Jika tidak, tambahkan elemen itu pada tatasusunan sementara. Berikut ialah kod sampel yang menggunakan kaedah in_array untuk melaksanakan penyahduaan tatasusunan:

function array_unique_in_array($array) {
    $temp = array(); // 临时数组
    foreach ($array as $value) {
        if (in_array($value, $temp)) {
            continue; // 已经出现过的元素,跳过
        }
        $temp[] = $value; // 新元素,添加到临时数组中
    }
    return $temp; // 返回去重后的数组
}
Salin selepas log masuk

Dalam kod di atas, kami menggunakan fungsi in_array() untuk menentukan sama ada elemen telah muncul dalam tatasusunan sementara. Jika elemen tidak wujud, ia akan ditambahkan pada tatasusunan sementara. Akhirnya, kami mengembalikan hasil penduaan.

Ringkasnya, terdapat banyak kaedah dalam PHP untuk melaksanakan algoritma penyahduplikasian tatasusunan Bergantung pada keperluan pelaksanaan tertentu, kita boleh memilih kaedah pengisihan penyahduplikasian tatasusunan, kaedah nilai kunci cincang dan kaedah in_array kaedah lain untuk mencapai tujuan penyahduplikasian tatasusunan.

Atas ialah kandungan terperinci PHP melaksanakan algoritma penyahduplikasian tatasusunan. 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 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
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 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 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 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,

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 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

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.

See all articles