PHP数组:
$arr = array(0,15,60,120,2200);
我在函数中传递了一个带有数组值的$number = 12
,然后返回值应为0
我在函数中传递了一个带有数组值的$number = 15
,然后返回值应为15
我尝试使用以下代码,但没有运气
<?php
function get_less_value($arr, $number) {
foreach ($arr as $val) {
if ($val>= $number && $val < $number) return $val;
}
return end($arr);
}
echo get_less_value($arr, $number);
?>
答案 0 :(得分:2)
array_filter
是您要找的方法。我想有足够的方法可以做到这一点:)
$array = [0, 15, 60, 120, 2200];
$number = 15;
$filtered = array_filter($array, function($element) use ($number) {
return ($element <= $number);
});
// $filtered = [0, 15];
$max = max($filtered); //15
答案 1 :(得分:2)
这永远不会成真:
if ($val>= $number && $val < $number)
我会尝试:
$highest = 0;
foreach ($arr as $val) {
if($val <= $number){
if($val >= $highest){
$highest= $val;
}
}
}
return $highest;
答案 2 :(得分:2)
您可以从最后搜索如果数组排序正确,只需查找不超过$ number的第一个值就可以更简单并将其返回。
$result = false;
foreach(array_reverse($arr) as $v)
{
if($v <= $number)
{
$result = $v;
break;
}
}
if($result !== false)
echo $result;
答案 3 :(得分:0)
您也可以使用此功能:
function get_less_value($arr, $number) {
// Always sort the array first
sort($arr);
$i = 0;
$biggest = 0;
while ($number >= $arr[$i]) {
$biggest = $arr[$i];
$i++;
}
return $biggest;
}
echo get_less_value($arr, $number);
这是天真的解决方案,如果您的阵列非常大,可能会运行缓慢。 看看搜索算法。例如:Binary Search
关于算法的另一个PDF:http://epaperpress.com/sortsearch/download/sortsearch.pdf