假设我有一个这样的数组:
$my_array = array(1, 2, 3, 4, array(11, 12, 13, 14), 6, 7, 8, array(15, 16, 17, 18), 10);
我想构建一个递归函数,该函数返回一个数组,该数组包含 my_array
中的所有偶数。我试过类似的东西:
function get_even_numbers($my_array)
{
$even_numbers = array();
foreach($my_array as $my_arr)
{
if(is_array($my_arr)
{
get_even_numbers($my_arr);
foreach($my_arr as $value)
{
if($value % 2 == 0)
{
$even_numbers[] = $value;
}
}
}
}
return even_numbers;
}
但它不起作用。
谢谢
最佳答案
很简单:
- 检查函数的输入是否为数组。
- 如果是,那意味着你必须遍历数组的值,并调用你的函数(所以它是递归的)
- 否则,只检查传入的值是否为偶数,然后将其添加到数组中返回。
在 PHP 中,它看起来像:
function recursive_even( $input) {
$even = array();
if( is_array( $input)) {
foreach( $input as $el) {
$even = array_merge( $even, recursive_even( $el));
}
}
else if( $input % 2 === 0){
$even[] = $input;
}
return $even;
}
关于php - 递归地向数组添加元素并返回新数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16159091/