当前位置: 首页 > news >正文

服务专业的网站制作服务抖音十大搜索关键词

服务专业的网站制作服务,抖音十大搜索关键词,深圳南山做网站的公司,配资网站开发Problem: 295. 数据流的中位数 文章目录 题目描述思路解题方法复杂度Code 题目描述 思路 由于该题目的数据是动态的我们可以维护两个堆来解决该问题 1.维护一个大顶堆,一个小顶堆 2.每个堆中元素个数接近n/2;如果n是偶数,两个堆中的数据个数…

Problem: 295. 数据流的中位数

文章目录

  • 题目描述
  • 思路
  • 解题方法
  • 复杂度
  • Code

题目描述

在这里插入图片描述
在这里插入图片描述

思路

由于该题目的数据是动态的我们可以维护两个来解决该问题

1.维护一个大顶堆,一个小顶堆
2.每个堆中元素个数接近n/2;如果n是偶数,两个堆中的数据个数都是n/2;如果n是奇数,则大顶堆中有n/2 + 1个数据,小顶堆中有n/2个数据
3.大顶堆中的数据值都要小于小顶堆中的数据值

即大顶堆中的堆顶元素就是中位数

解题方法

1.(创建堆)按思路创建一个大顶堆和小顶堆
2.(维护堆):

2.1.如果新插入数据小于等于大顶堆,则将其插入到大顶堆中,否则插入到小顶堆;
2.2.插入数据后,两个堆中的数据量个数不满足思路中的要求2,则我们需要从一个堆中不停的将堆顶元素移动到另一个堆

image.png

复杂度

时间复杂度:

a d d N u m : O ( l o g n ) addNum:O(logn) addNum:O(logn)
f i n d M e d i a n : O ( 1 ) findMedian:O(1) findMedian:O(1)

空间复杂度:

O ( n ) O(n) O(n)

Code

class MedianFinder {/*维护一个大顶堆和小顶堆*/private PriorityQueue<Integer> minQueue = new PriorityQueue<>(new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return o1 - o2;}});private PriorityQueue<Integer> maxQueue = new PriorityQueue<>(new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return o2 - o1;}});public MedianFinder() {}/*** 数据流插入数据** @param num 待插入的数据*/public void addNum(int num) {//如果插入数据小于等于大顶堆堆顶元素,大顶堆直接插入if (maxQueue.isEmpty() || num <= maxQueue.peek()) {maxQueue.add(num);} else {minQueue.add(num);}//大顶堆数据量不能小于小顶堆while (maxQueue.size() < minQueue.size()) {Integer minQueueElement = minQueue.poll();maxQueue.add(minQueueElement);}//小顶堆数据量可以比大顶堆小一个while (minQueue.size() < maxQueue.size() - 1) {Integer maxQueueElement = maxQueue.poll();minQueue.add(maxQueueElement);}}/*** 找出中位数** @return double*/public double findMedian() {//如果大顶堆数据量大于小顶堆if (maxQueue.size() > minQueue.size()) {return maxQueue.peek();} else {return (maxQueue.peek() + minQueue.peek()) / 2f;}}
}/*** Your MedianFinder object will be instantiated and called as such:* MedianFinder obj = new MedianFinder();* obj.addNum(num);* double param_2 = obj.findMedian();*/
http://www.yidumall.com/news/57724.html

相关文章:

  • 洛阳做网站公司哪家好google登录
  • 如何在第三方网站做推广seo优化方向
  • 有了主机和域名后如何做网站短链接
  • 专门做推荐的网站怎么搭建属于自己的网站
  • 济南天桥区网站建设微商已经被国家定为传销了
  • 做网站banner课程封面嘉兴seo外包平台
  • 百度网站优化新十条优化措施
  • 管理网络的应用软件网站排名优化外包
  • 智慧医疗软件公司排名石家庄seo网络优化的公司
  • 高校两学一做网站建设网站销售怎么推广
  • 网站网络推广教程品牌推广手段
  • 中山网站建设哪家好快速刷排名的软件最好
  • 一建建设网站兰州网站开发公司
  • 做公司seo网络培训班
  • 马云1688网站在濮阳如何做推广计划
  • 图书销售网站设计怎么做厨师培训
  • 网站怎么做后台百度搜索风云榜官网
  • 企业标志logo关键词优化工具有哪些
  • 高明网站设计服务品牌策划案
  • 同一虚拟主机 2个网站seo研究中心倒闭
  • 广州古柏广告策划有限公司长沙seo
  • 网站制作一键生成活动推广软文
  • 在线客服系统源码带appseo百度推广
  • 漂亮公司网站源码打包下载推广资源seo
  • ps做网站浏览器预览baidu百度首页
  • 网站建设所需知识广州网络推广
  • 微网站开发工具有哪些百度账号登录个人中心
  • 阿里巴巴网站建设免费商丘网站建设公司
  • 陈村建网站软件优化
  • 电子商务网站建设专业主修课程seo建站的步骤