多维数组计算差集

     大家都知道一维数组计算差集的内置函数是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));


posted on 2017-05-26 21:43 mthoutai 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/mthoutai/p/6910552.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值