Preparando MOJI

Tiles for Bathroom

5000ms 524288K

Description:

Kostya is extremely busy: he is renovating his house! He needs to hand wallpaper, assemble furniture throw away trash.

Kostya is buying tiles for bathroom today. He is standing in front of a large square stand with tiles in a shop. The stand is a square of $$$n \times n$$$ cells, each cell of which contains a small tile with color $$$c_{i,\,j}$$$. The shop sells tiles in packs: more specifically, you can only buy a subsquare of the initial square.

A subsquare is any square part of the stand, i. e. any set $$$S(i_0, j_0, k) = \{c_{i,\,j}\ |\ i_0 \le i < i_0 + k, j_0 \le j < j_0 + k\}$$$ with $$$1 \le i_0, j_0 \le n - k + 1$$$.

Kostya still does not know how many tiles he needs, so he considers the subsquares of all possible sizes. He doesn't want his bathroom to be too colorful. Help Kostya to count for each $$$k \le n$$$ the number of subsquares of size $$$k \times k$$$ that have at most $$$q$$$ different colors of tiles. Two subsquares are considered different if their location on the stand is different.

Input:

The first line contains two integers $$$n$$$ and $$$q$$$ ($$$1 \le n \le 1500$$$, $$$1 \le q \le 10$$$) — the size of the stand and the limit on the number of distinct colors in a subsquare.

Each of the next $$$n$$$ lines contains $$$n$$$ integers $$$c_{i,\,j}$$$ ($$$1 \le c_{i,\,j} \le n^2$$$): the $$$j$$$-th integer in the $$$i$$$-th line is the color of the tile in the cell $$$(i,\,j)$$$.

Output:

For each $$$k$$$ from $$$1$$$ to $$$n$$$ print a single integer — the number of subsquares of size $$$k \times k$$$ with no more than $$$q$$$ different colors.

Sample Input:

3 4
1 2 3
4 5 6
7 8 9

Sample Output:

9
4
0

Sample Input:

4 8
1 2 3 4
5 6 7 8
9 1 2 3
4 5 6 7

Sample Output:

16
9
4
0

Note:

In the first example all colors are distinct. Kostya doesn't want the subsquare have more than $$$4$$$ colors, so he can buy any subsquare of size $$$1 \times 1$$$ or $$$2 \times 2$$$, but he can't buy a subsquare of size $$$3 \times 3$$$.

In the second example there are colors that appear multiple times. Because $$$q = 8$$$, Kostya can buy any subsquare of size $$$1 \times 1$$$ and $$$2 \times 2$$$, and any subsquare $$$3 \times 3$$$, because of such subsquare has $$$7$$$ different colors. He can't buy the whole stand $$$4 \times 4$$$, because there are $$$9$$$ colors.

Informação

Codeforces

Provedor Codeforces

Código CF1500D

Tags

data structuressortingstwo pointers

Submetido 0

BOUA! 0

Taxa de BOUA's 0%

Datas 09/05/2023 10:12:12

Relacionados

Nada ainda