题目: PHP 实现数据流中的中位数
描述:
如何得到一个数据流中的中位数?
如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。
如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。
<?php$bigTop = new SplMaxHeap();
$smallTop = new SplMinHeap();function Insert($num)
{// write code hereglobal $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 hereglobal $bigTop;global $smallTop;return $smallTop->count() == $bigTop->count() ? ($smallTop->top() + $bigTop->top())/2 : $smallTop->top();
}