问题描述
<?PHP
$tableau = [[[[2],[2]],[[2],[2]]],[[[2],[2]]]];
function test_count_recursive($tab,$compte = 0){
foreach($tab as $ss_tab){
if(!is_array($ss_tab)){
$compte += 1;
}
else{
test_count_recursive($ss_tab,$compte);
}
}
return $compte;
}
echo test_count_recursive($tableau);
但它不起作用,你能告诉我为什么吗?
解决方法
通常,您将一段数据向上或向下传递递归调用树,而不是两者。在这种情况下,您不需要向下传递父值。只需返回计数并让父节点累加即可:
<?php
function test_count_recursive($tab /* one param only */) {
$compte = 0; // <-- store the local total for this node
foreach ($tab as $ss_tab) {
if (is_array($ss_tab)) {
$compte += test_count_recursive($ss_tab /* one param only */);
// ^^^^^^^ accumulate total from children
}
else {
$compte++;
}
}
return $compte;
}
$tableau = [[[[2],[2]],[[2],[2]]],[[[2],[2]]]];
echo test_count_recursive($tableau); // => 8