You can listen to 10-minute introduction by Peter Szarvas and Rinat Abdullin or read the summary below.
There is a map containing a Factory, Port, Warehouse A and Warehouse B. Factory has a small stock of containers that have to be delivered to these warehouses.
There are two trucks and one ship that can carry one container at a time (trucks start at Factory, ship starts at the Port).
Traveling takes a specific amount of hours (represented by an orange number). Time is needed to travel in one direction, you also spend the same amount of time to come back. For example, it takes 5 hours for a truck to travel from the Factory to B.
Transport follows a simple heuristic: pick the first container from the location (first-in, first - out), bring it to the designation, then come back home.
Truck that drops off cargo at the Port doesn't need to wait for the ship (there is a small warehouse buffer there). It can drop the cargo and start heading back. Cargo loading and unloading is an instant operation.
Transport moves in parallel. First truck might be bringing container to a location A, while the second truck comes back from A, while ship travels back to the Port.
Task: write a program that takes a list of cargos from the command line and prints out the number of hours that it would take to get them delivered.
Input | Output |
---|---|
A | 5 |
AB | 5 |
BB | 5 |
ABB | 7 |
AABABBAB | ? |
ABBBABAAABBB | ? |
When done, feel free to add link to your solution to the solution list.
-
Don't worry about making the code extensible. We will evolve the codebase, but the deeper domain dive will have to start from the scratch.
-
Don't worry if your numbers don't exactly match answers from your colleagues. There is a small loop-hole in the exercise that makes it non-deterministic. We will address it later.
-
While picking the language for the exercise, pick whatever that would let you solve the problem quicker. If you are itching to try out a new fancy language that you are less familiar with, there will be a chance for that later.
-
Remember that all processes happen in parallel. Trucks and ship would be moving around the map at the same time, not sequentially.
-
Don't worry about applying any patterns (e.g. aggregates or events) at this point. Just get the job done. Implementation patterns will emerge in the codebase later.
- What is the possible reason for the different solutions to return different answers?
- Link your solution in the solution list.
Next exercise is available.