数据流中的中位数【Java版】

数据流中的中位数

http://www.nowcoder.com/practice/9be0172896bd43948f8a32fb954e1be1

【总体思路】设立一个大根堆、一个小根堆,还有一个奇偶标记。
大根堆保存较小的半边,小根堆大的半边;入堆来回倒(以保证中位)、出堆类型转换

import java.util.PriorityQueue;
//Java的PriorityQueue基于堆
//add()添加  poll()弹出顶端元素=>时间都是O(logN)    //peek()查看顶端元素=>时间O(1)
//【poll】比较特别,相当于栈的pop
public class Solution {
    PriorityQueue<Integer> minRootHeap = new PriorityQueue<Integer>();//小根堆
    PriorityQueue<Integer> maxRootHeap = new PriorityQueue<Integer>((x,y) -> y-x);//大根堆:用lambda表达式 调整顺序
    boolean isOdd = false;//可以设置boolean,也可以设置一个Int类型的++i
    //3个全局(类)变量,空间复杂度O(N)

    public void Insert(Integer num) {
        if(isOdd == false){
            minRootHeap.add(num);//插入小根堆  //由于是中位数,所以是对称的,反过来也可
            maxRootHeap.add(minRootHeap.poll());//小根堆最小值,给到大根堆
        }
        else{
            maxRootHeap.add(num);
            minRootHeap.add(maxRootHeap.poll());
        }
        isOdd = !isOdd;
    }//时间O(logN) 空间O(1)

    public Double GetMedian() {//输出的类型是Double
        if(isOdd == true){
            return maxRootHeap.peek() / 1.0;//【强制转换】成Double
        }
        else{
            return (maxRootHeap.peek() + minRootHeap.peek()) / 2.0;
        }
    }//时间O(1) 空间O(1)
}

int 和 Integer 的区别:

1、Integer是int的包装类,int则是java的一种基本数据类型
2、Integer变量必须实例化后才能使用,而int变量不需要
3、Integer实际是对象的引用,当new一个Integer时,实际上是生成一个指针指向此对象;而int则是直接存储数据值
4、Integer的默认值是null,int的默认值是0

深化:

1、由于Integer变量实际上是对一个Integer对象的引用,所以两个通过new生成的Integer变量永远是不相等的(因为new生成的是两个对象,其内存地址不同)。

Integer i = new Integer(100);
Integer j = new Integer(100);
System.out.print(i == j); //false

2、Integer变量和int变量比较时,只要两个变量的值是向等的,则结果为true(因为包装类Integer和基本数据类型int比较时,java会自动拆包装为int,然后进行比较,实际上就变为两个int变量的比较)

Integer i = new Integer(100);
int j = 100;
System.out.print(i == j); //true

3、非new生成的Integer变量和new Integer()生成的变量比较时,结果为false。(因为非new生成的Integer变量指向的是java常量池中的对象,而new Integer()生成的变量指向堆中新建的对象,两者在内存中的地址不同)

Integer i = new Integer(100);
Integer j = 100;
System.out.print(i == j); //false

4、对于两个非new生成的Integer对象,进行比较时,如果两个变量的值在区间 -128 ~ +127之间,则比较结果为true,如果两个变量的值不在此区间,则比较结果为false

Integer i = 100;
Integer j = 100;
System.out.print(i = = j); //true
Integer i = 128;
Integer j = 128;
System.out.print(i = = j); //false
《剑指Offer-Java题解》 文章被收录于专栏

《剑指Offer-Java题解》

全部评论

相关推荐

1 收藏 评论
分享
牛客网
牛客企业服务