You can simply run "test cases.py" ., it will execute the "waterplatform.py" output against the testcases given as text file "test0.txt".
You may run by making your own test case file file as format in one of the test case or you can directly run "waterplatform.py".
The approach used in solving this problem is given "approach.txt".
I have used min Heap to solve this problem, Priority queues & BFS , Depth first search (to find the lowest) could also be used but they would lead to more time consumption. All the necessary working has been mentioned for easy understanding of function.
-
Initially the heap contains all cells on the perimeter of the map.
-
The first cell popped is the lowest point on the outer wall.
-
Checking the 4 neighbours, ignoring any already explored (in the heap or have already been popped off the heap) or outside the map.
-
If a newly discovered neighbour is lower than the current cell then water can be added on top of it.
-
We know the water cannot flow out anywhere because the current cell is the lowest.
-
Add the water to this neighbouring cell (zero if neighbour is higher than cell) and push neighbour with its new height onto the heap.
-
We are effectively continually raising the water level, filling in any "holes" as we go.
[2] SPOJ
[3] Geeks for geeks: Rain water trapping