How does array_diff() work? It obviously couldn’t work as follows:
function array_diff($arraya, $arrayb)
{
$diffs = array();
foreach ($arraya as $keya => $valuea)
{
$equaltag = 0;
foreach ($arrayb as $valueb)
{
if ($valuea == $valueb)
{
$equaltag =1;
break;
}
}
if ($equaltag == o)
{
$diffs[$keya]=$valuea;
}
}
return $diffs;
} //couldn't be worse than this
Does anyone know a better solution?
EDIT @animuson:
function array_diff($arraya, $arrayb)
{
foreach ($arraya as $keya => $valuea)
{
if (in_array($valuea, $arrayb))
{
unset($arraya[$keya]);
}
}
return $arraya;
}
UPDATE
see below for faster/better code.
array_diff behaviour is much better in php 5.3.4, but still ~10 times slower than Leo’s function.
also it’s worth noting that these functions are not strictly equivalent to
array_diffsince they don’t maintain array keys, i.e.my_array_diff(x,y) == array_values(array_diff(x,y))./UPDATE
A better solution is to use hash maps
benchmark
result
any questions? 😉
and, just for fun,
result
that’s incredible!