时间:2021-07-01 10:21:17 帮助过:16人阅读
例如有一个多维数组:
array(
array(
array(1,3,4),
array(
array(
1,2,3
)
)
),
array(
array(1,2),
array(1)
)
)
这个数组的深度就是5,那么如何快速的确定一个数组深度.
解决方案1:
使用SPL中的Iterator,在RecursiveIteratorIterator 类中有个getDepth方法,获得深度
解决方案2:
解决方案3:
$arr = array(array( array(array(“5″, “6″), “7″, “8″)),2,array(array(array(“5″, “6″), “7″, “8″,array( “7″,“8″))),4); echo getArrDemp($arr); function getArrDemp($array){ static $offset = 0; $arr_str = serialize($array); $num = substr_count($arr_str,'{'); $result = array(); for($i=0;$i<$num;$i++){ $l_pos = strpos($arr_str, '{', $offset); $temp_str = substr($arr_str,0,$l_pos); $offset = $l_pos + 1; $result[] = substr_count($temp_str,'{')-substr_count($temp_str,'}'); } array_multisort($result,SORT_DESC); return ++$result[0]; }
解决方案4:递归实现
解决方案5:简单的计算深度函数:
$max_depth) { $max_depth = $depth; } } } return $max_depth; } $array = array( array("11"), array(),array( array(array("5", "6"), "7", "8")),array( array(array("5", "6"), "7", "8")), "9", "10"); echo array_depth($array); ?>