• 剑指:数据流中的中位数


    题目描述

    如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。我们使用Insert()方法读取数据流,使用GetMedian()方法获取当前读取数据的中位数。

    解法

    利用大根堆存放较小的一半元素,小根堆存放较大的一半元素。维持大小堆的元素个数差不超过 1。

    import java.util.Comparator;
    import java.util.PriorityQueue;
    
    public class Solution {
    
        private PriorityQueue<Integer> minHeap = new PriorityQueue<>();
        private PriorityQueue<Integer> maxHeap = new PriorityQueue<>(Comparator.reverseOrder());
    
        /**
         * 插入一个数
         *
         * @param num 数
         */
        public void Insert(Integer num) {
    
            if (maxHeap.isEmpty() || num < maxHeap.peek()) {
                maxHeap.offer(num);
                if (maxHeap.size() - minHeap.size() > 1) {
                    minHeap.offer(maxHeap.poll());
                }
    
            } else {
                minHeap.offer(num);
                if (minHeap.size() - maxHeap.size() > 1) {
                    maxHeap.offer(minHeap.poll());
                }
            }
        }
    
        /**
         * 获取中位数
         *
         * @return 中位数
         */
        public Double GetMedian() {
            int size1 = maxHeap.size();
            int size2 = minHeap.size();
            if (size1 > size2) {
                return (double) maxHeap.peek();
            }
            if (size1 < size2) {
                return (double) minHeap.peek();
            }
    
            return (maxHeap.peek() + minHeap.peek()) / 2.0;
        }
    }
  • 相关阅读:
    Maven ==> 简介
    IDEA结合GIT的使用
    Shell ==> 基础
    Dubbo ==> 简介
    iptables防火墙
    文件系统对比
    supervisord部署
    inotify+rsync安装配置
    前端插件网址
    Nginx高级玩法
  • 原文地址:https://www.cnblogs.com/lisen10/p/11290752.html
Copyright © 2020-2023  润新知