多维数组计算差集

     大家都知道一维数组计算差集的内置函数是array_diff_assoc($array1, $array2),但是多维数组如何计算差集呢,就需要写一个相应的算法。我写了一个算法供大家参考。

      

<?php
//多维数组的差集
function array_diff_assoc_recursive($array1,$array2){
    $diffarray=array();
    foreach ($array1 as $key=>$value){
      //判断数组每个元素是否是数组
     if(is_array($value)){
      //判断第二个数组是否存在key
       if(!isset($array2[$key])){
           $diffarray[$key]=$value;
       //判断第二个数组key是否是一个数组
       }elseif(!is_array($array2[$key])){
           $diffarray[$key]=$value;
       }else{
           $diff=array_diff_assoc_recursive($value, $array2[$key]);
           if($diff!=false){
             $diffarray[$key]=$diff;
           }
       }
     }elseif(!array_key_exists($key, $array2) || $value!==$array2[$key]){
          $diffarray[$key]=$value;
     }
    }
    return $diffarray;  
}
$array1=array(1,2,3,array(1,2,array(1)));
$array2=array(1,2,4,array(1,2,3));
print_r(array_diff_assoc_recursive($array1,$array2));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值