3

例如,我有一个数组(它可以是任何东西,但它已经订购了):

array(1,7, 12, 18, 25);

我需要找到最接近该数组的数字。

取上面的数组:

$needle = 11;

我要检索的数组中的数字是7. 最接近的数字11应该是12,但我不想要最接近的数字,我想要最接近的次要数字,如果这有任何意义的话。

另一个例子:

  • 输入26检索到的号码应该是25
  • 输入1检索到的号码应该是1
  • 输入6检索到的号码应该是1
  • 输入7检索到的号码应该是7
  • 输入16检索到的号码应该是12

我找到了一个不错的函数,但它只检索最接近的数字,而不是次要的最接近的数字:

function closestnumber($number, $candidates) {
 for($i = 0; $i != sizeof($candidates); $i++) {
  $results[$i][0] = abs($candidates[$i] - $number);
  $results[$i][1] = $i;
 }
 sort($results);
 $end_result['closest'] = $candidates[$results[0][1]];
 $end_result['difference'] = $results[0][0];
 return $end_result;
}

$closest = closestnumber(8,array(1,7, 12, 18, 25));
echo "Closest: ".$closest['closest']."<br>";
echo "Difference: ".$closest['difference'];

提前致谢。

4

3 回答 3

5
$myArray = array(1,7, 12, 18, 25); 
$needle = 11; 

$resultKey = array_search(max(array_intersect(array_values($myArray),range(0,$needle))),$myArray); 
$result = $myArray[$resultKey];

编辑

假设数组值总是正整数

简化版

$myArray = array(1,7, 12, 18, 25); 
$needle = 11; 

$result = max(array_intersect(array_values($myArray),range(0,$needle))); 
于 2010-12-12T18:40:52.123 回答
2

这看起来像家庭作业,但我会幽默地告诉你:

function closestnumber($number, $candidates) {
    $last = null;
    foreach ($candidates as $cand) {
        if ($cand < $number) {
            $last = $cand;
        } else if ($cand == $number) {
            return $number;
        } else if ($cand > $number) {
            return $last;
        }
    }
    return $last;
}
于 2010-12-12T18:18:01.793 回答
1

仅测试小于或等于您的人数的候选人。如果您始终只记住最佳解决方案,则无需对解决方案进行排序即可找到最佳解决方案。

所以试试这个:

function closestnumber($number, $candidates) {
    $best = null;
    foreach ($candidates as $candidate) {
        if ($candidate <= $number) {
            if (is_null($best) || $diff > $number - $candidate) {
                $diff = $number - $candidate;
                $best = $candidate;
            }
        }
    }
    if (is_null($best)) {
        return false;
    }
    return array('closest' => $best, 'difference' => $diff);
}
于 2010-12-12T18:36:51.090 回答