Skip to content

Instantly share code, notes, and snippets.

@ischenkodv
Created December 23, 2009 23:33
Show Gist options
  • Save ischenkodv/262906 to your computer and use it in GitHub Desktop.
Save ischenkodv/262906 to your computer and use it in GitHub Desktop.
function calculate_median($arr) {
$count = count($arr); //total numbers in array
$middleval = floor(($count-1)/2); // find the middle value, or the lowest middle value
if($count % 2) { // odd number, middle is the median
$median = $arr[$middleval];
} else { // even number, calculate avg of 2 medians
$low = $arr[$middleval];
$high = $arr[$middleval+1];
$median = (($low+$high)/2);
}
return $median;
}
function calculate_average($arr) {
$count = count($arr); //total numbers in array
foreach ($arr as $value) {
$total = $total + $value; // total value of array numbers
}
$average = ($total/$count); // get average value
return $average;
}
@bishopb
Copy link

bishopb commented Oct 24, 2016

For the scenario where the data set has non-numeric keys (or no elements):

function median(array $arr)
{
    if (0 === count($arr)) {
        return null;
    }

    // sort the data
    $count = count($arr);
    asort($arr);

    // get the mid-point keys (1 or 2 of them)
    $mid  = floor(($count - 1) / 2);
    $keys = array_slice(array_keys($arr), $mid, (1 === $count % 2 ? 1 : 2));
    $sum  = 0;
    foreach ($keys as $key) {
        $sum += $arr[$key];
    }
    return $sum / count($keys);
}

@joshi1983
Copy link

These solutions are nicely understandable but not optimally efficient since they involve fully sorting the array before getting the median out of it.

The optimal efficiency for getting a median is actually O(n) not O(n log n). Have you tried implementing Hoare's Selection algorithm in PHP?
Someone else mentioned it at: http://stackoverflow.com/questions/4201292/on-algorithm-to-find-the-median-of-a-collection-of-numbers

@grenoult
Copy link

As BramVanroy and other mentioned, array needs to be sorted. In my case I used sort($arr);.

@steffanhalv
Copy link

Rewritten from javascript https://stackoverflow.com/a/45309555/2298745

Median PHP:

function median($values) {
  $count = count($values);
  if ($count === 0)  return null;
  asort($values);
  $half = floor($count / 2);
  if ($count % 2) return $values[$half];
  return ($values[$half - 1] + $values[$half]) / 2.0;
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment