-
Notifications
You must be signed in to change notification settings - Fork 0
/
median_stream.py
49 lines (43 loc) · 1.46 KB
/
median_stream.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
class MedianFinder:
def __init__(self):
"""
initialize your data structure here.
"""
self.data_stream = []
def addNum(self, num: int) -> None:
if self.data_stream:
n = len(self.data_stream)
l = 0
h = n - 1
m = int(n // 2)
while True:
if num == self.data_stream[m]:
self.data_stream.insert(m, num)
return
if num < self.data_stream[m]:
if l == m:
self.data_stream.insert(l, num)
return
else:
h = m - 1
m = (h + l) // 2
elif num > self.data_stream[m]:
if h == m:
self.data_stream.insert(h + 1, num)
return
else:
l = m + 1
m = (h + l) // 2
self.data_stream.append(num)
def findMedian(self) -> float:
n = len(self.data_stream)
if n == 1:
return self.data_stream[0]
if n % 2:
return self.data_stream[int(n / 2)]
return (self.data_stream[int((n - 1) / 2) + 1] + self.data_stream[int((n - 1) / 2)]) / 2
"""
https://leetcode.com/problems/find-median-from-data-stream/
["MedianFinder","addNum","addNum","findMedian","addNum","findMedian"]
[[],[1],[2],[],[3],[]]
"""