WATER SPOJ Statement
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.
You may also like:
WATER SPOJ Hint
You can solve this problem via BFS (Breadth First Search). Bellow is solution in C++.
using namespace std;
typedef pair<int,pair<int,int> > PIII;
priority_queue<PIII,vector<PIII>,greater<PIII> > Q;
for (i=0; i<R; i++)
for (j=0; j<C; j++)
if (P2.first>P.first) break;
for (i=0; i<4; i++)
// fprintf(stderr,"%d %d\n",R,C);