gpt4 book ai didi

php - 递归地向数组添加元素并返回新数组

转载 作者:行者123 更新时间:2023-12-05 08:28:14 25 4
gpt4 key购买 nike

假设我有一个这样的数组:

$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;
}

但它不起作用。

谢谢

最佳答案

很简单:

  1. 检查函数的输入是否为数组。
  2. 如果是,那意味着你必须遍历数组的值,并调用你的函数(所以它是递归的)
  3. 否则,只检查传入的值是否为偶数,然后将其添加到数组中返回。

在 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com