codeforces#P178E3. The Beaver's Problem - 2
The Beaver's Problem - 2
Description
Offering the ABBYY Cup participants a problem written by the Smart Beaver is becoming a tradition. He proposed the following problem.
You are given a monochrome image, that is, an image that is composed of two colors (black and white). The image is given in raster form, that is, as a matrix of pixels' colors, and the matrix's size coincides with the size of the image.
The white color on the given image corresponds to the background. Also, the image contains several black geometric shapes. It is known that the image can contain only two types of shapes: squares and circles. Your task is to count the number of circles and the number of squares which the given image contains.
The squares on the image can be rotated arbitrarily. In addition, the image can possibly contain some noise arranged as follows: each pixel of the original image can change its color to the opposite with the probability of 20%.
The first input line contains a single integer n (1000 ≤ n ≤ 2000), which is the length and the width of the original image.
Next n lines describe the matrix of colors of the image pixels. The i-th line contains exactly n integers aij (0 ≤ aij ≤ 1), separated by spaces. Value of aij = 0 corresponds to a white pixel and aij = 1 corresponds to a black one.
It is guaranteed that the lengths of the sides of the squares and the diameters of the circles in the image are at least 15 pixels, and the distance between any two figures is at least 10 pixels. It is also guaranteed that a human can easily calculate the number of circles and squares in the original image. The total number of figures in the image doesn't exceed 50.
The input limitations for getting 20 points are:
- These test cases have no noise and the sides of the squares are parallel to the coordinate axes.
The input limitations for getting 50 points are:
- These test cases have no noise, but the squares are rotated arbitrarily.
The input limitations for getting 100 points are:
- These test cases have noise and the squares are rotated arbitrarily.
Print exactly two integers, separated by a single space — the number of circles and the number of squares in the given image, correspondingly.
Input
The first input line contains a single integer n (1000 ≤ n ≤ 2000), which is the length and the width of the original image.
Next n lines describe the matrix of colors of the image pixels. The i-th line contains exactly n integers aij (0 ≤ aij ≤ 1), separated by spaces. Value of aij = 0 corresponds to a white pixel and aij = 1 corresponds to a black one.
It is guaranteed that the lengths of the sides of the squares and the diameters of the circles in the image are at least 15 pixels, and the distance between any two figures is at least 10 pixels. It is also guaranteed that a human can easily calculate the number of circles and squares in the original image. The total number of figures in the image doesn't exceed 50.
The input limitations for getting 20 points are:
- These test cases have no noise and the sides of the squares are parallel to the coordinate axes.
The input limitations for getting 50 points are:
- These test cases have no noise, but the squares are rotated arbitrarily.
The input limitations for getting 100 points are:
- These test cases have noise and the squares are rotated arbitrarily.
Output
Print exactly two integers, separated by a single space — the number of circles and the number of squares in the given image, correspondingly.
Note
You are given a sample of original data for each difficulty level. The samples are available at http://codeforces.ru/static/materials/contests/178/e-samples.zip .