赞
踩
描述:
如何得到一个数据流中的中位数?
如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。
如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。
<?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(); }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。