Kerumitan algoritma penyahduplikasi tatasusunan PHP: array_unique(): O(n)array_flip() + array_keys(): O(n)gelung foreach: O(n^2)
Terokai kerumitan algoritma penyahduplikasian PHP
Pengenalan
Dalam PHP, penyahduplikasi tatasusunan ialah operasi biasa. Terdapat beberapa algoritma berbeza yang boleh digunakan untuk melakukan ini, masing-masing dengan kerumitannya sendiri. Artikel ini akan meneroka kerumitan algoritma penyahduplikasi tatasusunan yang paling biasa dalam PHP.
Algoritma deduplikasi tatasusunan
Dalam PHP, terdapat pelbagai algoritma penyahduplikasi tatasusunan untuk dipilih, termasuk:
Kes praktikal
Berikut ialah kes praktikal untuk mengalih keluar pendua dalam tatasusunan rentetan:
<?php // 输入数组 $inputArray = ["a", "b", "c", "a", "d", "e", "c"]; // 使用 array_unique() 去重 $uniqueArray = array_unique($inputArray); // 输出去重后的数组 print_r($uniqueArray); ?>
Kerumitan
Algorithm | |
---|---|
array_unique() | |
array_flip() + array_keys() | |
(untuk setiap gelung) |
Memilih algoritma penyahduplikasi tatasusunan terbaik bergantung pada saiz tatasusunan dan overhed prestasi yang dijangkakan. Untuk tatasusunan yang lebih kecil, gelung foreach mungkin pilihan yang boleh diterima. Walau bagaimanapun, untuk tatasusunan yang lebih besar, array_unique() atau array_flip() + array_keys() akan memberikan prestasi yang lebih baik.
Atas ialah kandungan terperinci Meneroka kerumitan algoritma penyahduplikasi tatasusunan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!