WATER - Water among Cubes
On a rectangular mesh comprising n*m fields, n*m cuboids were put, one cuboid on each field. A base of each cuboid covers one field and its surface equals to one square inch. Cuboids on adjacent fields adhere one to another so close that there are no gaps between them. A heavy rain pelted on a construction so that in some areas puddles of water appeared.
Write a program which:
- reads from the standard input a size of the chessboard and heights of cuboids put on the fields,
- computes maximal water volume, which may gather in puddles after the rain,
- writes results in the standard output.
The number of test cases t is in the first line of input, then t test cases follow separated by an empty line. In the first line of each test case two positive integers 1 <= n <= 100, 1 <= m <= 100 are written. They are the size of the mesh. In each of the following n lines there are m integers from the interval [1..10000]; i-th number in j-th line denotes a height of a cuboid given in inches put on the field in the i-th column and j-th raw of the chessboard.
Your program should write for each tes case one integer equal to the maximal volume of water (given in cubic inches), which may gather in puddles on the construction.
Sample input: 1 3 6 3 3 4 4 4 2 3 1 3 2 1 4 7 3 1 6 4 1 Sample output: 5
The picture below shows the mesh after the rain (seen from above). Puddles are drawn in gray.
Finally AC after 7 days............start from the minimum height and then to the maximum height......
Finally AC !!!!!!! my 46th. @crypt is right
@crypt shouldn't the answer for your mentioned test case be 76.
This problem requires a very advance thought process . :p AC after 3 days .
great problem :)
bfs/dfs doesn't get any better than this :)
n^2 log(n) dijkshtra :)
very nice logic, thanks :)
Aseem Raj Baranwal:
Last edit: 2016-02-02 10:39:17
Awesome Problem !Last edit: 2015-06-11 09:08:13