PHP获得数组的交集与差集

数组的交集 array_intersect()

array_intersect()函数返回一个保留了键的数组,这个数组只由第一个数组中出现的且在其他每个输入数组中都出现的值组成。其形式如下:

1     array array_intersect(array array1,array array2[,arrayN…])  

下面这个例子将返回在$fruit1数组中出现的且在$fruit2和$fruit3中也出现的所有的水果:

 1     <?php  
 2     $fruit1 = array("Apple","Banana","Orange");  
 3     $fruit2 = array("Pear","Apple","Grape");  
 4     $fruit3 = array("Watermelon","Orange","Apple");  
 5     $intersection = array_intersect($fruit1, $fruit2, $fruit3);  
 6     print_r($intersection);  
 7       
 8     // output  
 9     // Array ( [0] => Apple )  
10     ?>  

只有在两个元素相等且具有相同的数据类型时,array_intersect()函数才会认为它们是相同的。

关联数组的交集 array_intersect_assoc()

函数array_intersect_assoc()与array_intersect()基本相同,只不过他在比较中还考虑了数组的键。因此,只有在第一个数组中出现,且在所有其他输入数组中也出现的键/值对才返回到结果数组中。

形式如下:

1     array array_intersect_assoc(array array1,array array2[,arrayN…])  

下面的例子返回了出现在$fruit1数组中,也同时出现在$fruit2与$fruit3中的所有键/值对:

 1     <?php  
 2     $fruit1 = array("red"=>"Apple","yellow"=>"Banana","orange"=>"Orange");  
 3     $fruit2 = array("yellow"=>"Pear","red"=>"Apple","purple"=>"Grape");  
 4     $fruit3 = array("green"=>"Watermelon","orange"=>"Orange","red"=>"Apple");  
 5     $intersection = array_intersect_assoc($fruit1, $fruit2, $fruit3);  
 6     print_r($intersection);  
 7       
 8     // output  
 9     // Array ( [red] => Apple )  
10     ?>  

数组的差集 array_diff()

函数array_diff()返回出现在第一个数组中但其他输入数组中没有的值。这个功能与array_intersect()相反。

1     array array_diff_assoc(array array1,array array2[,arrayN…])  

下面的例子只返回了[yellow] => Banana,因为这个特殊的键/值对出现在$fruit1中,而在$fruit2和$fruit3中都不存在。

 1     <?php  
 2     $fruit1 = array("red"=>"Apple","yellow"=>"Banana","orange"=>"Orange");  
 3     $fruit2 = array("yellow"=>"Pear","red"=>"Apple","purple"=>"Grape");  
 4     $fruit3 = array("green"=>"Watermelon","orange"=>"Orange","red"=>"Apple");  
 5     $intersection = array_diff_assoc($fruit1, $fruit2, $fruit3);  
 6     print_r($intersection);  
 7       
 8     // output  
 9     // Array ( [yellow] => Banana )  
10     ?>  

转自:http://blog.csdn.net/k8080880/article/details/24910317

posted @ 2017-12-01 11:06  huohuohiahia  阅读(133)  评论(0)    收藏  举报