ホームページ  >  記事  >  バックエンド開発  >  求高效率算法找

求高效率算法找

WBOY
WBOYオリジナル
2016-06-13 11:57:37998ブラウズ

求高效算法找

$a = array(<br />    'A' => array(1,2,3,4,5,6),<br />    'B' => array(1,7,8,9),<br />    'C' => array(1,6,7,8,9),<br />)<br />    <br />    <br />$b = array(<br />    '2','4'<br />)<br />    求高效算法找出 $b数组  属于数组 $a  A、B、C的那一项的子集,注 $a,$b 数量不确定  

------解决方案--------------------
$a = array(<br />    'A' => array(1,2,3,4,5,6),<br />    'B' => array(1,7,8,9),<br />    'C' => array(1,6,7,8,9),<br />);<br />     <br />$b = array(<br />    '2','4'<br />);<br /><br />$r = array_filter($a, function($t) use ($b) {<br />  return array_intersect($b, $t) == $b;<br />});<br /><br />print_r($r);
Array<br />(<br />    [A] => Array<br />        (<br />            [0] => 1<br />            [1] => 2<br />            [2] => 3<br />            [3] => 4<br />            [4] => 5<br />            [5] => 6<br />        )<br /><br />)<br /><br />

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。