This is a rephrasing of the common Counting Change problem. The explanation of how to solve the Dynamic Programming problem and the concept of overlapping sub-problems are discussed here.
It seems as if 2 groups have copied from this website, one successfully, one unsuccessfully😝.
The method of solving has practically been laid out. You can see my implementation in Julia (legible to anyone who knows python) here. 2 groups have almost got it right, 1 completed it. This is a Monte Carlo simulation. For further understanding of many kinds of simulations, use this coursera course on Simulation and modeling of natural processes.
This is the common Delivery Problem, and is a problem in graph theory. It is further complicated by the fact that the distances are non-euclidean(the WHs). A more complex version of it is used in any sort of delivery app (Swiggy etc.). This Coursera Course has a very nice explanation. Here is a shorter explanation and implementation.
The first part is a Context Free Grammar.
- L => A
- A => 0A | 0B | 0
- B => 11A | 11
This can be implemented with a Push Down Automaton. (Take IDC 204 if you are interested)
But this can also be done using a regex. Check Perpetual Motion Squad's implementation.
The second part is a basic encoding mechanism. Commonly used are ascii and unicode.
This is a common way to solve a double differential equation. You can see my implementation in Julia here. Try extending to 3d, and also use the Barnes Hut optimization. More details in the Simulation and modeling of natural processes Coursera course.
This was rather straightforward, but some groups misunderstood the question. See my implementation here.
The following are the scores -
The following are the participants' code -
- Primes - Primes.zip
- Binod@69 - [email protected]
- JARVIS - JARVIS.zip
- Perpetual Motion Squad - Perpetual_Motion_Squad.zip