Leetcode: 295. Find Median from Data Stream

Problem Statement

from sortedcontainers import SortedList


class MedianFinder:
    def __init__(self):
        self.s = SortedList()

    def addNum(self, num: int) -> None:
        self.s.add(num)

    def findMedian(self) -> float:
        N = len(self.s)
        if N % 2 == 0:
            return (self.s[N // 2] + self.s[N // 2 - 1]) / 2
        return self.s[N // 2]


# Your MedianFinder object will be instantiated and called as such:
# obj = MedianFinder()
# obj.addNum(num)
# param_2 = obj.findMedian()