44、PHP 实现数据流中的中位数(含源码)

题目: 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();
}
相关推荐
鹧鸪晏8 分钟前
搞懂 kotlin 泛型 out 和 in 关键字
android·kotlin
毕设源码-邱学长9 分钟前
【开题答辩全过程】以 基于Android的“旧时光”书店App为例,包含答辩的问题和答案
android
hashiqimiya11 分钟前
androidstudio历史版本
android
毕设源码-钟学长13 分钟前
【开题答辩全过程】以 基于Android的出租车运行监测系统设计与实现为例,包含答辩的问题和答案
android
fatiaozhang952714 分钟前
晶晨S905W2芯片_sbx_x98_plus_broagcon_atv_安卓11_线刷包固件包
android·电视盒子·刷机固件·机顶盒刷机·机顶盒刷机固件大全·晶晨s905w2芯片
匆忙拥挤repeat18 分钟前
Android Compose 依赖配置解读
android
没有了遇见40 分钟前
Android 关于注入Js处理Android和H5 Js 交互问题
android
加密狗复制模拟41 分钟前
软件加密狗中时间限制机制的破解
开发语言·网络·安全·php·软件工程·个人开发
阿拉斯攀登1 小时前
第 12 篇 RK 平台安卓驱动实战 5:SPI 设备驱动开发,以 SPI 屏 / Flash 为例
android·驱动开发·rk3568·瑞芯微·嵌入式驱动·安卓驱动·spi 设备驱动
Predestination王瀞潞1 小时前
Mysql忘记密码重置的方法
android·mysql·adb