Rumah >pembangunan bahagian belakang >masalah PHP >Bagaimana untuk melaksanakan deduplikasi tatasusunan dalam php

Bagaimana untuk melaksanakan deduplikasi tatasusunan dalam php

藏色散人
藏色散人asal
2022-01-12 10:17:0311393semak imbas

Cara melaksanakan deduplikasi tatasusunan dalam PHP: 1. Gunakan kaedah array_unique untuk menyahduplikasi elemen tatasusunan 2. Gunakan kaedah array_flip untuk menyahduplikasi.

Bagaimana untuk melaksanakan deduplikasi tatasusunan dalam php

Persekitaran pengendalian artikel ini: sistem Windows 7, PHP versi 7.1, komputer DELL G3

deduplikasi pantas elemen tatasusunan php

1. Gunakan kaedah array_unique untuk menyahduplikasi

Untuk menyahduplikasi elemen tatasusunan, kami biasanya menggunakan kaedah array_unique.

<?php
$arr = array(1,1,2,3,3,3,4,4,5,6,6,7,8,8,9,9,9);
$arr = array_unique($arr);
$arr = array_values($arr);
print_r($arr);
?>

Output:

Array
(
    [0] => 1
    [1] => 2
    [2] => 3
    [3] => 4
    [4] => 5
    [5] => 6
    [6] => 7
    [7] => 8
    [8] => 9
)

Selepas penyahduplikasi, nilai kunci akan menjadi tidak teratur Anda boleh menggunakan array_values ​​​​untuk menyusun semula nilai kunci.

2. Kecekapan menggunakan kaedah array_unique untuk mengalih keluar pendua

<?php
$arr = array();
// 创建100000个随机元素的数组
for($i=0; $i<100000; $i++){
    $arr[] = mt_rand(1,99);
}
// 记录开始时间
$starttime = getMicrotime();
// 去重
$arr = array_unique($arr);
// 记录结束时间
$endtime = getMicrotime();
$arr = array_values($arr);
echo &#39;unique count:&#39;.count($arr).&#39;<br>&#39;;
echo &#39;run time:&#39;.(float)(($endtime-$starttime)*1000).&#39;ms<br>&#39;;
echo &#39;use memory:&#39;.getUseMemory();
/**
 * 获取使用内存
 * @return float
 */
function getUseMemory(){
    $use_memory = round(memory_get_usage(true)/1024,2).&#39;kb&#39;;
    return $use_memory;
}
/**
 * 获取microtime
 * @return float
 */
function getMicrotime(){
    list($usec, $sec) = explode(&#39; &#39;, microtime());
    return (float)$usec + (float)$sec;
}
?>
unique count:99
run time:653.39303016663ms
use memory:5120kb

Menggunakan kaedah array_unique untuk mengalih keluar pendua, masa berjalan mengambil masa kira-kira 650ms dan memori penggunaan adalah kira-kira 5m

3 Kaedah penyahduplikasi tatasusunan yang lebih pantas

php mempunyai kaedah pertukaran nilai kunci array_flip, kita boleh menggunakan kaedah ini untuk menyahduplikasi, kerana kunci- pertukaran nilai, Nilai pendua asal akan menjadi kunci yang sama.

Kemudian laksanakan pertukaran nilai kunci, dan tukar semula kunci dan nilai untuk melengkapkan penduadua.

<?php
$arr = array();
// 创建100000个随机元素的数组
for($i=0; $i<100000; $i++){
    $arr[] = mt_rand(1,99);
}
// 记录开始时间
$starttime = getMicrotime();
// 使用键值互换去重
$arr = array_flip($arr);
$arr = array_flip($arr);
// 记录结束时间
$endtime = getMicrotime();
$arr = array_values($arr);
echo &#39;unique count:&#39;.count($arr).&#39;<br>&#39;;
echo &#39;run time:&#39;.(float)(($endtime-$starttime)*1000).&#39;ms<br>&#39;;
echo &#39;use memory:&#39;.getUseMemory();
/**
 * 获取使用内存
 * @return float
 */
function getUseMemory(){
    $use_memory = round(memory_get_usage(true)/1024,2).&#39;kb&#39;;
    return $use_memory;
}
/**
 * 获取microtime
 * @return float
 */
function getMicrotime(){
    list($usec, $sec) = explode(&#39; &#39;, microtime());
    return (float)$usec + (float)$sec;
}
?>
unique count:99
run time:12.840032577515ms
use memory:768kb

Menggunakan kaedah array_flip untuk menyahduplikasi, masa berjalan mengambil masa kira-kira 18ms, dan penggunaan memori adalah kira-kira 2m

Oleh itu, menggunakan kaedah array_flip untuk menyahduplikasi masa berjalan adalah 98% lebih pendek daripada menggunakan kaedah array_unique dikurangkan sebanyak 4/5;

Pembelajaran yang disyorkan: "Tutorial Video PHP"

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan deduplikasi tatasusunan dalam 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