5

我有一个这样的数组

 array(
      45=>5,
      42=>4.9,
      48=>5,
      41=>4.8,
      40=>4.9,
      34=>4.9,
      .....
      )

这里 index 是userid,value 是他的分数。

现在我想要为用户实现百分位数,例如 45,48 的百分位数为 99,42,40,34 为 97,41 为 94。

我怎样才能做到这一点?

4

2 回答 2

9
  1. 根据“分数”对数组进行排序,升序
  2. Percentile = (排序数组中元素的索引) * 100 / (数组中的总元素)

例子:

<?php
$array = array(
      45=>5,
      42=>4.9,
      48=>5,
      41=>4.8,
      40=>4.9,
      34=>4.9,
      );

print("Unsorted array:<br/>");
print_r($array);
arsort($array);
print("<br/>");
print("Sorted array:<br/>");
print_r($array);
print("<br/>");

$i=0;
$total = count($array);
$percentiles = array();
$previousValue = -1;
$previousPercentile = -1;
foreach ($array as $key => $value) {
    echo "\$array[$key] => $value";
    if ($previousValue == $value) {
    $percentile = $previousPercentile;
    } else {
    $percentile = 99 - $i*100/$total;
    $previousPercentile = $percentile;
    }
    $percentiles[$key] = $percentile;
    $previousValue = $value;
    $i++;
}

print("Percentiles:<br/>");
print_r($percentiles);
print("<br/>");

?>
于 2012-08-23T11:01:54.163 回答
1

它可以更容易地完成

function procentile($arr, $percentile=0.95){
    sort($arr);
    return $arr[round($percentile * count($arr) - 1.0-$percentile)];
}
于 2014-01-10T11:59:43.863 回答