-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy path1396.DesignUndergroundSystem.py
99 lines (83 loc) · 4.52 KB
/
1396.DesignUndergroundSystem.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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
"""
Implement the class UndergroundSystem that supports three methods:
1. checkIn(int id, string stationName, int t)
- A customer with id card equal to id, gets in the station stationName at
time t.
- A customer can only be checked into one place at a time.
2. checkOut(int id, string stationName, int t)
- A customer with id card equal to id, gets out from the station
stationName at time t.
3. getAverageTime(string startStation, string endStation)
- Returns the average time to travel between the startStation and
the endStation.
- The average time is computed from all the previous traveling from
startStation to endStation that happened directly.
- Call to getAverageTime is always valid.
You can assume all calls to checkIn and checkOut methods are consistent.
That is, if a customer gets in at time t1 at some station, then it gets
out at time t2 with t2 > t1. All events happen in chronological order.
Example:
Input:
["UndergroundSystem","checkIn","checkIn","checkIn","checkOut","checkOut",
"checkOut","getAverageTime","getAverageTime","checkIn","getAverageTime",
"checkOut","getAverageTime"]
[[],[45,"Leyton",3],[32,"Paradise",8],[27,"Leyton",10],[45,"Waterloo",15],
[27,"Waterloo",20],[32,"Cambridge",22],["Paradise","Cambridge"],
["Leyton","Waterloo"],[10,"Leyton",24],["Leyton","Waterloo"],
[10,"Waterloo",38],["Leyton","Waterloo"]]
Output:
[null,null,null,null,null,null,null,14.00000,11.00000,null,11.00000,null,12.00000]
Explanation:
UndergroundSystem undergroundSystem = new UndergroundSystem();
undergroundSystem.checkIn(45, "Leyton", 3);
undergroundSystem.checkIn(32, "Paradise", 8);
undergroundSystem.checkIn(27, "Leyton", 10);
undergroundSystem.checkOut(45, "Waterloo", 15);
undergroundSystem.checkOut(27, "Waterloo", 20);
undergroundSystem.checkOut(32, "Cambridge", 22);
undergroundSystem.getAverageTime("Paradise", "Cambridge"); // return 14.00000.
// There was only one travel from "Paradise"
// (at time 8) to "Cambridge" (at time 22)
undergroundSystem.getAverageTime("Leyton", "Waterloo"); // return 11.00000.
// There were two travels from "Leyton" to "Waterloo",
// a customer with id=45 from time=3 to time=15 and
// a customer with id=27 from time=10 to time=20. So the
// average time is ( (15-3) + (20-10) ) / 2 = 11.00000
undergroundSystem.checkIn(10, "Leyton", 24);
undergroundSystem.getAverageTime("Leyton", "Waterloo"); // return 11.00000
undergroundSystem.checkOut(10, "Waterloo", 38);
undergroundSystem.getAverageTime("Leyton", "Waterloo"); // return 12.00000
Constraints:
- There will be at most 20000 operations.
- 1 <= id, t <= 10^6
- All strings consist of uppercase, lowercase English letters and digits.
- 1 <= stationName.length <= 10
- Answers within 10^-5 of the actual value will be accepted as correct.
"""
#Difficulty: Medium
#52 / 52 test cases passed.
#Runtime: 248 ms
#Memory Usage: 24.1 MB
#Runtime: 248 ms, faster than 95.57% of Python3 online submissions for Design Underground System.
#Memory Usage: 24.1 MB, less than 32.82% of Python3 online submissions for Design Underground System.
class UndergroundSystem:
def __init__(self):
self.ids = {}
self.station = {}
def checkIn(self, id: int, stationName: str, t: int) -> None:
self.ids[id] = [t, stationName]
def checkOut(self, id: int, stationName: str, t: int) -> None:
stations = (self.ids[id][1], stationName)
if stations not in self.station:
self.station[stations] = [t - self.ids[id][0]]
return
self.station[stations].append(t - self.ids[id][0])
def getAverageTime(self, startStation: str, endStation: str) -> float:
stations = (startStation, endStation)
length = len(self.station[stations])
return sum(self.station[stations]) / length
# Your UndergroundSystem object will be instantiated and called as such:
# obj = UndergroundSystem()
# obj.checkIn(id,stationName,t)
# obj.checkOut(id,stationName,t)
# param_3 = obj.getAverageTime(startStation,endStation)