伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

数据流中的中位数

来源:本站原创 浏览:104次 时间:2022-08-04

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

解题思路:使用最大堆和最小堆,如果插入个数是奇数,则是中间的数,如果是偶数,则是中间两数之和的一半,比如1,2,3,4,5,6,那么中位数就是中间两位之和的一半,现在问题就转换为怎么定位这两个数,所以可以使用最大堆和最小堆,根据堆的性质,最大堆的堆顶元素最大,最小堆的堆顶元素最小,最大堆用于保存前半部分的数(1,2,3),最小堆用于保存后半部分的数(4,5,6),当插入的个数是奇数时,返回最大堆的堆顶即是中位数,如果是偶数,则是最大堆的堆顶和最小堆的堆顶之和的一半,;此时最大堆的堆顶元素为3,最小堆的堆顶为4,所以中位数为两者之和的一半(3+4)/ 2.0 = 3.5。

public class Solution {    private int cnt = 0;    private PriorityQueue<Integer> low = new PriorityQueue<>();    private PriorityQueue<Integer> high = new PriorityQueue<>(   //默认是最小堆,最大堆需要重写方法    new Comparator<Integer>(){        public int compare(Integer o1, Integer o2){            return o2.compareTo(o1);        }    });    public void Insert(Integer num) {        ++cnt;         if((cnt & 1) == 1){            if(!low.isEmpty() && num > low.peek()){   //当最小堆不为空,并且待插入的数大于最小堆堆顶时弹出堆顶                 low.offer(num);                 num = low.poll();            }             high.offer(num);             }        else{            if(!high.isEmpty() && num < high.peek()){  //当最大堆不为空,并且待插入的数小于最大堆堆顶时弹出                high.offer(num);                num = high.poll();            }            low.offer(num);        }    }    public Double GetMedian() {        if((cnt & 1) == 1){   //插入个数为奇数            return high.peek() * 1.0;        }else{      //插入个数为偶数            return (high.peek() + low.peek()) / 2.0;
    }}

}

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net