具有可变量表的最高因素



PHP的floor()ceil()对于将浮子舍入到其最近的整数中很有用。

但是,如果我们需要为给定的数字找到10个(数百,千等(的最高倍数怎么办?例如:

num_to_scale(538.9)           // 500
num_to_scale(543123654.01234) // 5000000

尝试此代码,检查实时演示。您也可以参考此帖子。

  $floor = floor($v);
  return str_pad(substr($floor, 0, 1), strlen($floor), '0');
function num_to_scale($number) {
  $multiple=1; $test=1;
  for ($i=1; $test>=1; $i++) {
    $factor = $multiple/10;
    $test = $number/$multiple;
    $multiple = $multiple*10;
    $scale = floor($number/$factor)*$factor;
  } return $scale;
}

或更简单:

function num_to_scale($n) {
  $m=1; $t=1;
  for ($i=1; $t>=1; $i++) {
    $f=$m/10; $t=$n/$m; $m=$m*10; $s=floor($n/$f)*$f;
  } return $s;
}

与辅助功能结合使用以将整数转换为文本字符串,我们可以轻松地执行类似的操作:

echo 'Over '.num_to_scale(5395206).' units sold.';
// Over five million units sold.

尝试以下:

function num_to_scale($number) {
    $num = (int) floor($number);
    $ln = strlen($num) - 1;
    return (int) floor($num / pow(10, $ln)) * pow(10, $ln);
}

我的答案使用对数:

function num_to_scale($var) {
    $nbDigits = (int)log($var,10);
    return (int)($var/10**$nbDigits)*10**$nbDigits;
}

最新更新