news 2026/6/24 4:36:22

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【剑斩OFFER】算法的暴力美学——LeetCode 295 题:数据流的中位数


一、题目描述

二、算法原理

思路:建立大小堆

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

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

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

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

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

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

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

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

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

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

三、代码实现

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(); */
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/20 13:15:20

通义千问Embedding模型版本混乱?镜像标签管理实战指南

通义千问Embedding模型版本混乱&#xff1f;镜像标签管理实战指南 1. 背景与问题&#xff1a;Qwen3-Embedding-4B 的版本迷雾 随着大模型生态的快速发展&#xff0c;阿里通义实验室推出的 Qwen3 系列在多个任务场景中展现出卓越性能。其中&#xff0c;Qwen3-Embedding-4B 作为…

作者头像 李华
网站建设 2026/6/22 13:10:37

gpt-oss-20b-WEBUI调优实践:效率提升秘籍分享

gpt-oss-20b-WEBUI调优实践&#xff1a;效率提升秘籍分享 1. 引言&#xff1a;本地化推理的现实挑战与优化必要性 随着大语言模型&#xff08;LLM&#xff09;在各类应用场景中的广泛落地&#xff0c;开发者对高效、可控、低延迟的本地推理需求日益增长。gpt-oss-20b-WEBUI 镜…

作者头像 李华
网站建设 2026/6/16 7:17:25

小白也能懂的AI绘图:麦橘超然离线控制台保姆级教程

小白也能懂的AI绘图&#xff1a;麦橘超然离线控制台保姆级教程 1. 引言&#xff1a;为什么你需要一个本地AI绘图工具&#xff1f; 随着生成式AI技术的普及&#xff0c;越来越多用户希望借助AI进行艺术创作。然而&#xff0c;许多在线AI绘画平台存在响应慢、隐私泄露风险、中文…

作者头像 李华
网站建设 2026/6/22 2:54:15

OpenCode完全安装指南:5分钟开启你的AI编程新时代

OpenCode完全安装指南&#xff1a;5分钟开启你的AI编程新时代 【免费下载链接】opencode 一个专为终端打造的开源AI编程助手&#xff0c;模型灵活可选&#xff0c;可远程驱动。 项目地址: https://gitcode.com/GitHub_Trending/openc/opencode 还在为传统编程工具的效率…

作者头像 李华
网站建设 2026/6/15 12:10:40

C#开发的桌面应用如何生成绿色可执行文件?完整示例

如何让C#桌面应用真正“绿色”&#xff1f;一个文件拷来就用的实战指南你有没有遇到过这样的场景&#xff1a;辛辛苦苦写了个小工具&#xff0c;想发给同事试用&#xff0c;结果对方双击就报错——“缺少.NET运行时”&#xff1f;或者客户内网环境严格封锁&#xff0c;不允许安…

作者头像 李华
网站建设 2026/6/19 8:20:11

Youtu-2B部署效率低?生产级Flask封装优化实战

Youtu-2B部署效率低&#xff1f;生产级Flask封装优化实战 1. 背景与挑战&#xff1a;轻量模型的高可用服务需求 随着大语言模型&#xff08;LLM&#xff09;在端侧和边缘计算场景中的广泛应用&#xff0c;如何在有限算力条件下实现高效、稳定的推理服务成为工程落地的关键挑战…

作者头像 李华