-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Expand file tree
/
Copy pathdesign-ride-sharing-system.py
More file actions
55 lines (42 loc) · 1.21 KB
/
design-ride-sharing-system.py
File metadata and controls
55 lines (42 loc) · 1.21 KB
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
50
51
52
53
54
55
# Time: ctor: O(1)
# addRider: O(1)
# addDriver: O(1)
# matchDriverWithRider: O(1)
# cancelRider: O(1)
# Space: O(n)
import collections
# ordered dict
class RideSharingSystem(object):
def __init__(self):
self.__riders = collections.OrderedDict()
self.__drivers = collections.OrderedDict()
def addRider(self, riderId):
"""
:type riderId: int
:rtype: None
"""
self.__riders[riderId] = True
def addDriver(self, driverId):
"""
:type driverId: int
:rtype: None
"""
self.__drivers[driverId] = True
def matchDriverWithRider(self):
"""
:rtype: List[int]
"""
if not self.__riders or not self.__drivers:
return [-1, -1]
r = next(iter(self.__riders))
d = next(iter(self.__drivers))
del self.__riders[r]
del self.__drivers[d]
return [d, r]
def cancelRider(self, riderId):
"""
:type riderId: int
:rtype: None
"""
if riderId in self.__riders:
del self.__riders[riderId]