PHP递归问题

时间:2016-11-05 11:07:50

标签: php arrays recursion array-walk

您好我正在尝试在以下数组中找到最长的字符串:

$niza = array( array(5, 1.15 , 15),
array('unknown', 0.75 , 5, array(2, 'bla', 1.15) ),
array(array('text'), 1.15 , 7)

我正在使用以下功能,但我没有得到所需的结果,$len的值保持不变。你能救我吗?

function getLongest($array){
$longest="";
$len=0;

function arrWalk($item){
    global $len;
    global $longest;
    if(is_string($item)) {
        echo $len . "<br>";
        if (strlen($item) > $len) {
            $longest = $item;
            $len = strlen($item);
        }
    }
}

array_walk_recursive($array,'arrWalk');

echo $len;

}

arrWalk($niza);

3 个答案:

答案 0 :(得分:2)

要从数组中获取最长的字符串元素,可以在递归函数下面使用。

$niza = array(
    array(5, 1.15 , 15),
    array(
        'unknown', 0.75 , 5,
        array(2, 'bla', 1.15)
    ),
    array(array('text'), 1.15 , 7)
);

$longestString = '';
function getLongestString( $param )
{
    global $longestString;

    if ( is_array($param) )
    {
        foreach ($param as $val)
        {
            if ( is_string($val) && strlen($val) > strlen($longestString) )
            {
                $longestString = $val;
            }
            else
            {
                getLongestString( $val );
            }
        }
    }
    elseif ( is_string($param) && strlen($param) > strlen($longestString) )
    {
        $longestString = $param;
    }
}

getLongestString( $niza );

print $longestString;

答案 1 :(得分:0)

这是答案!

priv.c:122: error: undefined reference to 'hw_get_module'

答案 2 :(得分:0)

您可以使用以下有助于获得预期结果的代码

<?php


$niza = array(array(5, 1.15 , 15), array('unknown', 0.75 , 5, array(2, 'bla', 1.15) ), array(array('text'), 1.15 , 7));

$crew = '0'; // assign by default one value that count will be default 1

function getLongest($item, $key)
{
     global $crew;
     if(strlen($item)  >= strlen((string)$crew)){
    $crew = $item;
     }
}

array_walk_recursive($niza, 'getLongest');

echo $crew;
?>

您应该使用全局变量将lateste值存储在递归状态的变量中