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

shopify独立站seo门户网

shopify独立站,seo门户网,网站开发技术报告模板,中国智能机器人大会20211. 数据流中位数问题 题目 LeetCode295: 中位数是有序列表中间的数,如果列表长度是偶数,中位数是中间两个数的平均值, 例如:[2,3,4]的中位数是3, [2,3]中位数是(23)/ 2 2.5 设计一个数据结构: …

1. 数据流中位数问题

题目

 LeetCode295: 中位数是有序列表中间的数,如果列表长度是偶数,中位数是中间两个数的平均值,

例如:[2,3,4]的中位数是3,

[2,3]中位数是(2+3)/ 2= 2.5

设计一个数据结构:

void addNum(int num) 从数据流中添加一个整数到数据结构中

double findMedian()-返回目前所有元素的中位数。

思路

用大顶堆+小顶堆来求解,

小顶堆:存储所有元素中较大的一半,堆顶存储的是其中最小的数

大顶堆:存储所有元素中较小的一半,堆顶存储的是其中最大的数

相当于把元素分为两半,我们计算中位数,只需要小顶堆和大顶堆的根节点即可。

以[1,2,3,4,5]为例,砍成两半后为[1,2]和[3,4,5]我们只要能快速找到2和3即可。

下面看看使用两个堆是怎么变化的

  1. 添加1,进入minHeap中,中位数是1,
  2. 添加2,比民Heap堆顶元素1大,进入minHeap中,同时minHeap中元素超过了所有元素的总和的一半,所以要平衡一下,分一个给maxHeap,中位数是(1+2)/2=1.5.
  3. 添加3,它比minHeap堆顶的元素2大,进入minHeap,中位数为2。
  4. 添加4,比minHeap堆顶的元素2大,进入minHeap,,同时minHeap中元素超过了所有元素的总和的一半,所以要平衡一下,分一个给maxHeap,中位数是(2+3)/2=2.5.
  5. 添加5,它比minHeap堆顶的元素3大,进入minHeap,中位数为3。

代码

public class MediaFinder {//小顶堆存储的是比较大的元素,堆顶是其中的最小值PriorityQueue<Integer> minHeap;//大顶堆存储的是比较大的元素,堆顶是其中的最大值PriorityQueue<Integer> maxHeap;public MediaFinder(){this.minHeap = new PriorityQueue<Integer>();this.maxHeap = new PriorityQueue<Integer>((a, b) -> (b - a));}public void addNum(int num){//小顶堆存储的是比较大的元素,num比较大元素中最小的还大,所以,进入minHeapif (minHeap.isEmpty() || num > minHeap.peek()){minHeap.offer(num);//如果minHeap比maxHeap多两个元素,就平衡if (minHeap.size() - maxHeap.size() > 1){maxHeap.offer(minHeap.poll());}}else {maxHeap.offer(num);//这样可以保证多的那个元素一定在minHeap中if (maxHeap.size() - minHeap.size() > 0){minHeap.offer(maxHeap.poll());}}}public double findMedian(){if (minHeap.size() > maxHeap.size()){return minHeap.peek();} else if (minHeap.size() < maxHeap.size()) {return maxHeap.peek();}else {return (minHeap.peek() + maxHeap.peek())/2.0;}}
}

http://www.shuangfujiaoyu.com/news/3039.html

相关文章:

  • 鞍山网站建设网络营销的平台有哪些
  • 成都网站建设公司排行网站优化什么意思
  • 椒江做网站中央新闻频道直播今天
  • 个人团购网站 转入备案独立站怎么建站
  • 深圳宝安网站建设工营销推广活动策划
  • 漳州北京网站建设公司哪家好自助友链平台
  • vi设计公司模板seo顾问是什么职业
  • 汝州住房和城乡建设局网站北京网站快速排名优化
  • 用wordpress建站域名和空间哪里买比较好seo教程最新
  • 公司网站设计 上海百度推广业务电话
  • 大地资源影视免费观看南沙seo培训
  • 南昌公司网站开发上海站优云网络科技有限公司
  • 可做产品预售的网站百度端口开户推广
  • 网站开发规划宣传推广图片
  • 抖音代运营价格seo网站分析工具
  • 高端网站开发什么是sem推广
  • 豆芽网站建设douyanet站长之家网站排行榜
  • Gzip 网站 能够压缩图片吗深圳开发公司网站建设
  • .net wap网站模板新站优化案例
  • 什么是电子商务网站建设的基本要求全国疫情地区查询最新
  • win2003VPS装网站seo每日
  • 深圳网站建设制作设计公司视频外链平台
  • 国外网站设计欣赏百度app安装下载
  • vs做网站头部的代码武汉seo网络营销推广
  • 网站建设 设计创意企业营销策略有哪些
  • 网站做乘法表seo论坛
  • 网上做网站任务近期国际新闻热点大事件
  • 工业设计 做自己的网站 知乎北京全网营销推广
  • 属于网络营销站点推广的是广告网址
  • 网站搭建是哪个岗位做的事儿seo云优化如何