您好,登錄后才能下訂單哦!
利用PHP怎么輸出數(shù)組中重名的元素?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
1.可以直接用php的內(nèi)置函數(shù)array_intersect()
array array_intersect ( array $array1 , array $array2 [, array $ ... ] )
array_intersect() 返回一個數(shù)組,該數(shù)組包含了所有在 array1 中也同時出現(xiàn)在所有其它參數(shù)數(shù)組中的值。注意鍵名保留不變。
代碼:
復(fù)制代碼 代碼如下:
<?php
$array1 = array("a" => "green", "red", "blue");
$array2 = array("b" => "green", "yellow", "red");
$result = array_intersect($array1, $array2);
?>
輸出結(jié)果:
Array( [a] => green [0] => red)
2.也可以自己寫一個算法:
復(fù)制代碼 代碼如下:
<?php
function my_array_same($a){
$b = array_unique($a);
$r = array_diff_key($a,$b);
echo "<pre>";
$k=var_dump(array_unique($r));
return $k;
}
$a = array("red", "green", "pink", "red", "yellow","pink", "red");
$r=my_array_same($a);
var_dump(array_unique($r));
?>
輸出結(jié)果:
array(2) {
[3]=>
string(3) "red"
[5]=>
string(4) "pink"
}
3.還可以這么寫:
復(fù)制代碼 代碼如下:
<?php
function my_array_intersect($arr1,$arr2){
for($i=0;$i<count($arr1);$i++){
$temp[]=$arr1[$i];
}
for($i=0;$i<count($arr1);$i++){
$temp[]=$arr2[$i];
}
sort($temp);
$get=array();
for($i=0;$i<count($temp);$i++){
if($temp[$i]==$temp[$i+1])
$get[]=$temp[$i];
}
return $get;
}
$array1 = array("green", "red", "blue");
$array2 = array("green", "yellow", "red");
echo "<pre>";
print_r(my_array_intersect($array1, $array2));
echo "<pre/>";
?>
如果是一維的數(shù)組,第三種算法比第一種快點(diǎn).上述算法都適用于一維的數(shù)組,那么多維數(shù)組怎么查找相同的元素呢?
思路:可以把多維的數(shù)組轉(zhuǎn)化成一維的數(shù)組,然后再利用上述算法輸出。
代碼:
復(fù)制代碼 代碼如下:
function toarr($arr){ //對數(shù)組進(jìn)行遞歸,以字符串形式返回
foreach ($arr as $k=>$v){
if (!is_array($v)) {
$str.=$v." ";
}
else{
$str.=toarr($v);
}
}
return $str;
}/*遞歸函數(shù)結(jié)束*/
看完上述內(nèi)容,你們掌握利用PHP怎么輸出數(shù)組中重名的元素的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。