ホームページ >バックエンド開発 >PHPの問題 >PHPで配列の重複排除を実装する方法

PHPで配列の重複排除を実装する方法

藏色散人
藏色散人オリジナル
2022-01-12 10:17:0311398ブラウズ

php メソッドによる配列重複排除の実装: 1. array_unique メソッドを使用して配列要素の重複を排除します; 2. array_flip メソッドを使用して重複を排除します。

PHPで配列の重複排除を実装する方法

この記事の動作環境: Windows7 システム、PHP7.1 バージョン、DELL G3 コンピューター

php 配列要素の迅速な重複排除

1. array_unique メソッドを使用して重複を排除する

配列要素を重複排除するには、通常、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);
?>

出力:

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

重複排除後、キー値の順序が狂います。array_values を使用してキー値を並べ替えることができます。

2. array_unique メソッドを使用して重複を削除する効率

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

array_unique メソッドを使用して重複を削除すると、実行に約 650 ミリ秒かかり、約 5m のメモリが消費されます

3. 配列の重複排除を高速化する方法

php には、キーと値の交換メソッド array_flip があり、このメソッドを使用して重複を排除できます。キーと値の交換により、元の重複した値は削除されます。同じキーになります。

次に、キーと値の交換を再度実行し、キーと値を交換して重複排除を完了します。

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

array_flip メソッドを使用して重複を排除すると、実行時間は約 18 ミリ秒かかり、メモリ使用量は約 2 ミリ秒になります。

したがって、array_flip メソッドを使用して重複を排除すると、実行時間は 98% 短くなります。 array_unique メソッドを使用すると、メモリ使用量が 4/5 に削減されます。

推奨学習: 「PHP ビデオ チュートリアル

以上がPHPで配列の重複排除を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。