Defense of a Kingdom
Theodore implements a new strategy game "Defense of a Kingdom". On each level player defends the Kingdom that is represented by a rectangular grid of cells. The player builds crossbow towers in some cells of the grid. The tower defends all the cells in the same row and the same column. No two towers share a row or a column.
The penalty of the position is a number of cells in the largest undefended rectangle. For example, the position shown on the picture has penalty 12.
Help Theodore write a program that calculates the penalty of the given position.
Input
The first line contains three integer numbers: w - width of the grid, h - height of the grid and n - number of crossbow towers (1 ≤ w, h ≤ 40000; 0 ≤ n ≤ min(w, h)).
Each of the following n lines contains two integer numbers x[i]
and y[i]
- the coordinates of the cell occupied by a tower (1 ≤ x[i]
≤ w; 1 ≤ y[i]
≤ h).
Output
Output a single integer number - the number of cells in the largest rectangle that is not defended by the towers.