数据流中得中位数

旋转数组的最小数字

http://www.nowcoder.com/questionTerminal/9f3231a991af4f55b95579b44b7a01ba

链接说明

注意得点:
第一点:

import java.util.PriorityQueue;
public class Solution {
    PriorityQueue<Integer>  left=new PriorityQueue<>((n1,n2)->(n2-n1));////大根堆
    PriorityQueue<Integer>  right=new PriorityQueue<>((n1,n2)->(n1-n2));//小根堆
    int n;
    public void Insert(Integer num) {
        left.add(num);
        right.add(left.poll());
        if(right.size()-left.size()>1){
            left.add(right.poll());
        }


    }

    public Double GetMedian() {
        if(left.size()==right.size()){
            return (double) (left.poll()+right.poll())/2.0;
        }
        return (double)right.poll();
    }


}

为什么不行?比如你插入1,2,3
第二点:只能用peek(),不能用poll()

return (double)right.peek();
        }
         return (double) (left.peek()+right.peek())/2.0;
全部评论

相关推荐

不愿透露姓名的神秘牛友
10-04 05:12
kalistar:简历留六个字,北京大学(本科),黑体加粗,看看哪个hr不长眼敢碰瓷我们北大✌
点赞 评论 收藏
分享
10-28 10:48
已编辑
门头沟学院 Java
孩子我想要offer:发笔试后还没笔试把我挂了,然后邮箱一直让我测评没测,后面不知道干嘛又给我捞起来下轮笔试,做完测评笔试又挂了😅
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务