如何在给定范围内的多维数组中搜索最大值

时间:2014-07-03 21:14:50

标签: php arrays multidimensional-array

我有一个多维$array,它有很多不同的值。我试图获得给定范围内的最大值,在这种情况下,我们可以说x1,y0和x2,y7中的最大值,因此结果将是6使用下面的数据。

这似乎是在多维数组中在坐标内搜索的常见问题...但我找不到一个简单的解决方案,我尝试做的所有事情在编码中似乎相当广泛。我想知道是否有一个函数可以让我以有效的方式使用我的标准在这个数组中搜索。

$array[0][0] = 1;
$array[0][1] = 10;
$array[0][3] = 3;
$array[1[0] = 1;
$array[1][1] = 1;
$array[2][5] = 6;

3 个答案:

答案 0 :(得分:0)

$max = null;
for ($x = $startx; $x <= $endx; $x++) {
    for ($y = $starty; $y <= $endy; $y++) {
        if (isset($array[$x][$y]) && ($max === null || $array[$x][$y] > $max)) {
            $max = $array[$x][$y];
        }
    }
}

答案 1 :(得分:0)

$array[0][0] = 1;
$array[0][1] = 10;
$array[0][3] = 3;
$array[1][0] = 1;
$array[1][1] = 1;
$array[2][5] = 6;

$max = false;
$x1 = 1; $x2 = 2;
$y1 = 0; $y2 = 7;

foreach($array as $x => $y_vals) {    
    if($x < $x1 || $x > $x2)
        continue;

    foreach($y_vals as $y => $val) {
        if($y < $y1 || $y > $y2)
            continue;

        if(false === $max || $max < $val)
            $max = $val;
    }
}

print $max; //6

答案 2 :(得分:0)

$array[0][0] = 1;
$array[0][1] = 10;
$array[0][3] = 3;
$array[1][0] = 1;
$array[1][1] = 1;
$array[2][5] = 6;

$vals = array();
foreach (new RecursiveIteratorIterator(
             new RecursiveArrayIterator($array),
             RecursiveIteratorIterator::LEAVES_ONLY
         ) as $value) {
    $vals[] = $value;
}
$max = max($vals);
echo $max;