Skip to content

Instantly share code, notes, and snippets.

@kkt-ee
Created January 4, 2020 17:03
Show Gist options
  • Save kkt-ee/e8b842cbc7ba66b130244d23a769b687 to your computer and use it in GitHub Desktop.
Save kkt-ee/e8b842cbc7ba66b130244d23a769b687 to your computer and use it in GitHub Desktop.
"""
There is a queue for the self-checkout tills at the supermarket. Your task is write a function to calculate the total time required for all the customers to check out!
input
customers: an array of positive integers representing the queue. Each integer represents a customer, and its value is the amount of time they require to check out.
n: a positive integer, the number of checkout tills.
output
The function should return an integer, the total time required.
Important
Please look at the examples and clarifications below, to ensure you understand the task correctly :)
Examples
queue_time([5,3,4], 1)
# should return 12
# because when n=1, the total time is just the sum of the times
queue_time([10,2,3,3], 2)
# should return 10
# because here n=2 and the 2nd, 3rd, and 4th people in the
# queue finish before the 1st person has finished.
queue_time([2,3,10], 2)
# should return 12
Clarifications
There is only ONE queue serving many tills, and
The order of the queue NEVER changes, and
The front person in the queue (i.e. the first element in the array/list) proceeds to a till as soon as it becomes free.
N.B. You should assume that all the test input will be valid, as specified above.
P.S. The situation in this kata can be likened to the more-computer-science-related idea of a thread pool, with relation to running multiple processes at the same time: https://en.wikipedia.org/wiki/Thread_pool
"""
def queue_time(customers, n):
l=[0]*n
for i in customers:
l[l.index(min(l))]+=i
return max(l)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment