Use your language of choice. We use Go (backend), Typescript (frontend) and Dart (mobile) internally currently.
Please clone this repository using git and complete the problem described below in that repository. We prefer that you do not fork this repository; just clone it and commit your work to your local copy of the repository. If you are not familiar with git, you can find several guides online.
The .gitignore by default will ignore this directory, but if you have an additional IDE files or folders created please add them to your .gitignore
or specifically do not add them into the git repo. Please utilize the package manager tool for your language of choice:
- Go - go modules
- Javascript/Typescript - npm
When you start, you must create the file called started
that contains the current time at which you started. Please use RFC-3339 format with seconds level precision. Then commit this file only with the commit message of Starting Challenge
When you have completed the problem and commited your work to your local repository, zip the resulting directory and return the zipped solution to us by email. If the zip file is too large for email, you may host it using any storage solution you prefer (Dropbox, Google, Microsoft, ...) and send us the link.
You are to write a program to implement a grocery store / cashier line simulation. This program should read input from a file, and print the resulting score to the console. The program should be a console-only program. The program should take a single command line parameter: the name of the input file.
Customers in a grocery store arrive at a set of registers to check out. Each register is run by a cashier who serves customers on a first-come, first-served basis. The goal of the problem is to determine when all customers are done checking out.
One of the most important criteria for a successful solution is that it correctly implements the problem to be solved. This will be determined by code inspection, acceptance testing using the 5 examples demonstrated below, as well as additional test cases not provided on this page.
We will also be considering your overall approach to the problem and your programming style. This assignment is an opportunity to show off how you can use your object-oriented analysis and design skills to produce an elegant, readable, and maintainable solution. Please do NOT submit a multi-threaded or real-time solution. Please DO use what you would consider best practice in developing your solution.
The following should be available in your resulting solution zip file:
- Source Code
- Latest version of your language of choice (i.e., Go 1.16.x, Javascript ES7/8, Typescript 4.2.x)
- Unit tests
- Any other supporting code or other binaries that you used to develop the solution (even if it is not required to run the solution). If a resource is easily accessible on the web you can just provide a link to it rather than including the files.
- The number of registers is specified by the problem input file. Registers are numbered 1, 2, 3, ..., n for n registers.
- Time (
t
) is measured in minutes. - The grocery store always has a single cashier in training. This cashier is always assigned to the highest numbered register.
- Regular registers take one minute to process each customer's item. The register staffed by the cashier in training takes two minutes for each item. So a customer with
n
items at a regular register takesn
minutes to check out. However, if the customer ends up at the last register, it will take2n
minutes to check out. - The simulation starts at
t=0
. At that time all registers are empty (i.e. no customers are in line). - Two types of customers arrive at the registers:
- Customer Type A always chooses the register with the shortest line (least number of customers in line). If two or more registers have the shortest line, Customer Type A will choose the register with the lowest register number (e.g. register #1 would be chosen over register #3).
- Customer Type B looks at the last customer in each line, and always chooses to be behind the customer with the fewest number of items left to check out, regardless of how many other customers are in the line or how many items they have. Customer Type B will always choose an empty line before a line with any customers in it.
- Customers just finishing checking out do not count as being in line (for either kind of customer).
- If two or more customers arrive at the same time, those with fewer items choose registers before those with more items. If the customers have the same number of items, then type A customers choose before type B customers.
The first line of the input file is a single integer specifying the number of registers.
Each additional line is a whitespace-separated list of values. Each list specifies the customer type, customer arrival time (in minutes), and how many items that customer has respectively.
Review the below examples for sample input and output.
For the following input1.txt
file:
1
A 1 2
A 2 1
The following highlights occur:
- t=0 : Simulation starts with one register, which is a training register.
- t=1 : Customer #1 (type A) arrives with 2 items and goes to register #1, which starts servicing him.
- t=2 : Customer #2 (type A) arrives with 1 item and goes to register #1, behind Customer #1.
- t=3 : (Customer #1 now has one item left, since the first item took two minutes).
- t=5 : Customer #1 leaves and register #1 starts servicing Customer #2.
- t=7 : Customer #2 leaves.
Here is the expected command output:
$ go run main.go
Finished at: t=7 minutes
For the following input2.txt
file:
2
A 1 5
B 2 1
A 3 5
B 5 3
A 8 2
The following highlights occur:
- t=0 : Simulation starts with two registers; #2 is a training register.
- t=1 : Customer #1 (type A) arrives with 5 items and goes to register #1, which starts servicing him.
- t=2 : Customer #2 (type B) arrives with 1 item and goes to register #2 which starts servicing her.
- t=3 : Customer #3 (type A) arrives with 5 items. Since he is type A, he goes to register #1 (lowest number of two with equal number of customers), behind Customer #1.
- t=4 : Customer #2 leaves from register #2 (which took two minutes). (At this point, register #1 has 7 items total: 2 for Customer #1 and all 5 for Customer #3.)
- t=5 : Customer #4 (type B) arrives with 3 items. Since register #1 has customers with 6 items, and register #2 is empty, she goes to register #2 which starts servicing her.
- t=6 : Customer #1 leaves and register #1 starts servicing Customer #3.
- t=8 : Customer #5 (type A) arrives with 2 items. Since both registers have one person, she goes to register #1 behind Customer #3.
- t=11 : Customer #3 leaves and register #1 starts servicing Customer #5.
- t=11 : Customer #4 leaves from register #2.
- t=13 : Customer #5 leaves from register #1.
Here is the expected command output:
$ go run main.go
Finished at: t=13 minutes
For the following input3.txt
file:
2
A 1 2
A 1 2
A 2 1
A 3 2
Here is the expected command output:
$ go run main.go
Finished at: t=6 minutes
This example illustrates the requirement that departing customers are not counted in line.
For the following input4.txt
file:
2
A 1 2
A 1 3
A 2 1
A 2 1
Here is the expected command output:
$ go run main.go
Finished at: t=9 minutes
This example illustrates the requirement that customers with fewer items choose lines sooner.
For the following input5.txt
file:
2
A 1 3
A 1 5
A 3 1
B 4 1
A 4 1
Here is the expected command output:
$ go run main.go
Finished at: t=11 minutes
This example illustrates the requirement that customers of type A choose before customers of type B.