剑指offer面试题64 数据流中的中位数(Java实现)
来源:互联网 发布:内蒙古人民出版社 知乎 编辑:程序博客网 时间:2024/04/20 02:35
解题思路:具体见注释
import java.util.Comparator;import java.util.PriorityQueue;public class Solution {//记录数据容器中元素个数private int count = 0;//利用优先级队列实现小顶堆,PriorityQueue默认会对入队的元素进行排序,所以在队列顶端的总是最小的元素private PriorityQueue<Integer> minHeap = new PriorityQueue<>();//利用优先级队列实现大顶堆,根据指定的比较器comparator来排序其元素,所以在队列顶端的总是最大的元素private PriorityQueue<Integer> maxHeap = new PriorityQueue<Integer>(15, new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return o2 - o1;}});public void Insert(Integer num) {if (count % 2 == 0) {// 当数据总数为偶数时,新加入的元素,应当进入小根堆// (注意不是直接进入小根堆,而是经大根堆筛选后取大根堆中最大元素进入小根堆,//用于保证小顶堆中的最小的元素都比大顶堆中最大的元素还要大)// 1.新加入的元素先入到大根堆,由大根堆筛选出堆中最大的元素maxHeap.offer(num);//筛选出大顶堆中最大的元素int filteredMaxNum = maxHeap.poll();// 2.筛选后的【大根堆中的最大元素】进入小根堆minHeap.offer(filteredMaxNum);} else {// 当数据总数为奇数时,新加入的元素,应当进入大根堆// (注意不是直接进入大根堆,而是经小根堆筛选后取小根堆中最小元素进入大根堆)// 用于保证小顶堆中的最小的元素都比大顶堆中最大的元素还要大// 1.新加入的元素先入到小根堆,由小根堆筛选出堆中最小的元素minHeap.offer(num);int filteredMinNum = minHeap.poll();// 2.筛选后的【小根堆中的最小元素】进入大根堆maxHeap.offer(filteredMinNum);}count++;}public Double GetMedian() {if (count % 2 == 0) {return new Double((minHeap.peek() + maxHeap.peek())) / 2;} else {return new Double(minHeap.peek());}}}
阅读全文
0 0
- 剑指offer面试题64 数据流中的中位数(Java实现)
- 《剑指Offer》学习笔记--面试题64:数据流中的中位数
- 【剑指Offer学习】【面试题64:数据流中的中位数】
- 剑指offer-面试题64:数据流中的中位数
- 《剑指offer》面试题64 数据流中的中位数
- 剑指offer--面试题64:数据流中的中位数
- 剑指offer-面试题64-数据流中的中位数
- 剑指offer 面试题64 数据流中的中位数
- 剑指offer面试题[64]-数据流中的中位数
- 【剑指Offer】面试题64:数据流中的中位数
- 面试题64:数据流中的中位数
- 面试题64:数据流中的中位数
- 【面试题64】数据流中的中位数
- 面试题64:数据流中的中位数
- 【剑指offer】面试题41:数据流的中位数
- 剑指offer 64-数据流中的中位数
- 《剑指offer》:[64]数据流中的中位数
- 【剑指offer】题64:数据流中的中位数
- Unexpected server response (0) while retrieving PDF pdf.js加载url资源的问题
- Android中Bitmap和Drawable(转)
- MySQL创建数据库与用户以及授权
- 临时解决.net查询Mysql utf8mb4报给定关键字不在字典中
- 学习springmvc的第十六天(springmvc拦截器的3个方法)
- 剑指offer面试题64 数据流中的中位数(Java实现)
- python接口测试面试题
- android kotlin详解(1)
- git恢复被修改的文件
- Free Pascal IDE安装
- Java中泛型的基本知识
- #在ios9及以上系统中创建对话框并弹出
- C++ 一些常用函数
- Android Wi-Fi SeLinux打开后WiFi开关无响应(Android7.0/6.0)