web-dev-qa-db-ja.com

重複した配列phpをチェックして返します

配列に重複があるかどうかを確認し、重複した値を配列で返したいのですが。これをできるだけ効率的にしたいと思います。

Example :$array = array(1,2,2,4,5)
function returndup($array) should return 2 ;

if array is array(1,2,1,2,5);
it should return an array with 1,2

また、初期配列は常に5ポジションの長さです

27
NVG

これは、array_diffの約100倍高速です。

$dups = array();
foreach(array_count_values($arr) as $val => $c)
    if($c > 1) $dups[] = $val;
66
user187291

array_unique および array_diff_assoc

array_diff_assoc($arr, array_unique($arr))
15
Gumbo
function array_dup($ar){
   return array_unique(array_diff_assoc($ar,array_unique($ar)));
}

トリックを行う必要があります。

6
JAL

あなたはこのようにすることができます:

function showDups($array)
{
  $array_temp = array();

   foreach($array as $val)
   {
     if (!in_array($val, $array_temp))
     {
       $array_temp[] = $val;
     }
     else
     {
       echo 'duplicate = ' . $val . '<br />';
     }
   }
}


$array = array(1,2,2,4,5);
showDups($array);

出力:

duplicate = 2
4
Asif Raza
function returndup($array) 
{
    $results = array();
    $duplicates = array();
    foreach ($array as $item) {
        if (in_array($item, $results)) {
            $duplicates[] = $item;
        }

        $results[] = $item;
    }

    return $duplicates;
}
1
Ronn0

ガンボの答えに加えて:

function returndup($arr)
{
  return array_diff_key($arr, array_unique($arr));
}
1
faebser

私はいくつかのテストを行いましたが、確かに@ user187291のバリアントが最速です。しかし、@ Gumboと@faebserの代替はほぼ同じくらい高速で、@ faebserは@Gumboと比べてわずかに速く、時にはすべての中で最速であることが判明しました。

これが私が使ったコードです

$array = array(1, "hello", 1, "world", "hello");
$times = 1000000;

$start = microtime(true);
for ($i = 0; $i < $times; $i++) {
    $dups = array();
    foreach(array_count_values($array) as $val => $c)
        if( $c > 1) $dups[] = $val;
}
$end = microtime(true);

echo 'variant 1 (user187291): ' . ($end - $start);
echo '<br><br><br>';

$start = microtime(true);
for ($i = 0; $i < $times; $i++)
    $dups = array_unique(array_diff_assoc($array, array_unique($array)));
$end = microtime(true);

echo 'variant 2 (JAL): ' . ($end - $start);
echo '<br><br><br>';

$start = microtime(true);
for ($i = 0; $i < $times; $i++)
    $dups = array_diff_assoc($array, array_unique($array));
$end = microtime(true);

echo 'variant 3 (Gumbo): ' . ($end - $start);
echo '<br><br><br>';

$start = microtime(true);
for ($i = 0; $i < $times; $i++)
    $dups = array_diff_key($array, array_unique($array));
$end = microtime(true);

echo 'variant 4 (faebser): ' . ($end - $start);
echo '<br><br><br>';
0
Stefan Gabos

配列で重複を返す別の方法を見つけました

function printRepeating($arr, $size) 
{ 
    $i; 
    $j; 
    for($i = 0; $i < $size; $i++) 
        for($j = $i + 1; $j < $size; $j++) 
            if($arr[$i] == $arr[$j]) 
                echo $arr[$i], " "; 
}  



printRepeating($array, sizeof($array,0);
0
Nemo