题目: PHP 实现数据流中的中位数
描述:
如何得到一个数据流中的中位数?
如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。
如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。
php
<?php
$bigTop = new SplMaxHeap();
$smallTop = new SplMinHeap();
function Insert($num)
{
// write code here
global $bigTop;
global $smallTop;
//保证小顶堆的数 都大于大顶堆的数 其实就是小顶堆的顶 大于大顶堆的顶
if($smallTop->isEmpty() || $num >= $smallTop->top()){
$smallTop->insert($num);
}else{
$bigTop->insert($num);
}
if($smallTop->count() == $bigTop->count() + 2) $bigTop->insert($smallTop->extract());
if($smallTop->count() + 1 == $bigTop->count()) $smallTop->insert($bigTop->extract());
}
function GetMedian(){
// write code here
global $bigTop;
global $smallTop;
return $smallTop->count() == $bigTop->count() ? ($smallTop->top() + $bigTop->top())/2 : $smallTop->top();
}