The median is the middle value in an ordered integer list. If the size of the list is even, there is no middle value, and the median is the mean of the two middle values.
arr = [2,3,4], the median is 3.arr = [2,3], the median is (2 + 3) / 2 = 2.5.Implement the MedianFinder class:
MedianFinder() initializes the MedianFinder object.void addNum(int num) adds the integer num from the data stream to the data structure.double findMedian() returns the median of all elements so far. Answers within 10-5 of the actual answer will be accepted.Input
["MedianFinder", "addNum", "addNum", "findMedian", "addNum", "findMedian"]
[[], [1], [2], [], [3], []]
Output
[null, null, null, 1.5, null, 2.0]
Explanation
findMedian.addNum and findMedian. Follow up:
[0, 100], how would you optimize your solution?99% of all integer numbers from the stream are in the range [0, 100], how would you optimize your solution?In the brute force approach, every time we add a new number to our data structure, we will insert it into an existing list and sort it. This will allow us to easily compute the median by accessing the middle element(s) of the sorted list.
addNum(int num): Insert the incoming number into this array and then sort it.findMedian(): Access the middle element or the average of two middle elements to get the median.To optimize the process, we can use two heaps:
The median can be quickly found by:
addNum(int num):findMedian():