【剑斩OFFER】算法的暴力美学——LeetCode 295 题:数据流的中位数


一、题目描述

二、算法原理

思路:建立大小堆

如果这个数组是有序的,那么把他们的前半部分放到大根堆,后半部分放到小根堆,那么他们的中间值就是如果这两个堆的节点加起来是偶数,那么两个堆顶加起来 / 2 就行,那么如果是奇数那么返回大根堆的堆顶元素就行;

怎么让这两个数组的值是有序的:

1)约定:大根堆的节点数目可以比小根堆的多一个;

2)如果大根堆的节点数目 == 小根堆的节点数目,那么:

如果 :add 的值 num 大于 大根堆的堆顶,就放到小根堆里面,此时违反了约定,所以把小根堆的堆顶元素入大根堆,然后让小根堆 pop

如果:num <= 大根堆的堆顶元素 || 大根堆为空,那么直接入大根堆

3)如果大根堆的节点数目 > 小根堆的节点数目,那么:

如果:num > 大根堆的堆顶元素,直接入小根堆

如果:num <= 大根堆的堆顶元素,先入大根堆,再把大根堆的堆顶元素入小根堆,再让大根堆 pop

4)不存在大根堆的节点数目 < 小根堆的节点数目,因为上面的 3 条规则使然;

三、代码实现

cpp 复制代码
class MedianFinder {
public:
    MedianFinder() {
        
    }
    
    void addNum(int num) {
        if(maxi.size() == mini.size())
        {
            if(maxi.empty() || num <= maxi.top()) maxi.push(num);
            else
            {
                mini.push(num);
                maxi.push(mini.top());
                mini.pop();
            }
        }
        else if(maxi.size() > mini.size())
        {
            if(num > maxi.top()) mini.push(num);
            else
            {
                maxi.push(num);
                mini.push(maxi.top());
                maxi.pop();
            }
        }

        //因为上面的判断维持 maxi.size() > mini.size(),所以就不存在 maxi.size() < mini.size()
    }
    
    double findMedian() {
        if((maxi.size() + mini.size()) % 2 == 0) return ((double)maxi.top() + (double)mini.top()) / 2;
        else return maxi.top();
    }

private:
    priority_queue<int> maxi;//大堆
    priority_queue<int,vector<int>,greater<int>> mini;
};

/**
 * Your MedianFinder object will be instantiated and called as such:
 * MedianFinder* obj = new MedianFinder();
 * obj->addNum(num);
 * double param_2 = obj->findMedian();
 */
相关推荐
小O的算法实验室20 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生21 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿21 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz21 小时前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能21 小时前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****21 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ01 天前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法