-
Notifications
You must be signed in to change notification settings - Fork 154
/
Copy pathgetMinPlatforms.py
33 lines (25 loc) · 928 Bytes
/
getMinPlatforms.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
# Given the arrival and departure times of all trains
# that reach a railway station, the task is to find the
# minimum number of platforms required for the railway
# station so that no train waits.
# We are given two arrays that represent the arrival and
# departure times of trains that stop.
def getMinPlatforms(arr, dep):
if len(arr) != len(dep):
print("Wrong inputs given...")
return
else:
sorted_arr = sorted(arr + dep)
minPlatform = 0
trainsAtPlatform = 0
for i in sorted_arr:
if i in arr:
trainsAtPlatform += 1
if i in dep:
trainsAtPlatform -= 1
minPlatform = max(minPlatform, trainsAtPlatform)
return minPlatform
arrivalArr = [900, 940, 950, 1100, 1500, 1800]
departureArr = [910, 1200, 1120, 1130, 1900, 2000]
result = getMinPlatforms(arrivalArr, departureArr)
print("Minimum no. of platforms for given time table are: ", result)