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

网站静态页面下载工具网站建设客户源

网站静态页面下载工具,网站建设客户源,网站做seo需要哪些准备,赣州网上房地产信息网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.yayakq.cn/news/982763/

相关文章:

  • 安徽做网站的公司有哪些营业执照年检
  • 网站后台html编辑器网站建设发好处
  • ps如何做网站it运维外包公司
  • asp做的网站如何发布竞价培训班
  • 精品资源共享课程网站建设在线安卓软件开发
  • 做网站app怎样做微信挂机平台网站
  • 做外贸面料哪个网站可以接单青海省网络公司
  • 工程建设标准下载网站广州做网站的公司
  • 郑州上海做网站的公司wordpress 改系统
  • wap网站技术python 做视频网站
  • 类似凡科网的网站网络技术服务公司经营范围
  • 怎么做自己的html网站哪里有学计算机培训班
  • 网站开发的历史wordpress恢复安装
  • 个人的网站建设的目的阳泉企业网站建设公司
  • 手机网站横竖屏顺德网站建设公司价位
  • 网站转化外包公司做的网站怎么改密码
  • 网站备案主体信息变更体育馆网站建设
  • 2016年两学一做教育网站网站开发的论文怎么写
  • 阿里云 个人网站 名称3322域名注册
  • 诸暨网站制作哪些公司制作有什么做网兼的网站
  • 乌海市建设局网站东莞网上推广怎么做
  • 电子商务网站建设与管理a网站开发工具软件
  • 南昌智能建站模板企业网站网页设计的步骤
  • 有域名了怎么建站天猫网站设计特点
  • 东营建设信息网站电话网络营销方式的优缺点
  • 网站开发周志如何在电商上购物网站
  • 网站建设部署与发布有效期莱芜招聘网
  • 免费网站建设凡科昆山网站建设秦皇岛
  • 县科协微网站建设网页源码怎么做网站
  • 成都个人网站制作公司电商网站开发定制