Preparando MOJI

Cyclic Cipher

2000ms 262144K

Description:

You are given n sequences. Each sequence consists of positive integers, not exceeding m. All integers in one sequence are distinct, but the same integer may appear in multiple sequences. The length of the i-th sequence is ki.

Each second integers in each of the sequences are shifted by one to the left, i.e. integers at positions i > 1 go to positions i - 1, while the first integers becomes the last.

Each second we take the first integer of each sequence and write it down to a new array. Then, for each value x from 1 to m we compute the longest segment of the array consisting of element x only.

The above operation is performed for 10100 seconds. For each integer from 1 to m find out the longest segment found at this time.

Input:

The first line of the input contains two integers n and m (1 ≤ n, m ≤ 100 000) — the number of sequences and the maximum integer that can appear in the sequences.

Then follow n lines providing the sequences. Each of them starts with an integer ki (1 ≤ ki ≤ 40) — the number of integers in the sequence, proceeded by ki positive integers — elements of the sequence. It's guaranteed that all integers in each sequence are pairwise distinct and do not exceed m.

The total length of all sequences doesn't exceed 200 000.

Output:

Print m integers, the i-th of them should be equal to the length of the longest segment of the array with all its values equal to i during the first 10100 seconds.

Sample Input:

3 4
3 3 4 1
4 1 3 4 2
3 3 1 4

Sample Output:

2
1
3
2

Sample Input:

5 5
2 3 1
4 5 1 3 2
4 2 1 3 5
1 3
2 5 3

Sample Output:

3
1
4
0
1

Sample Input:

4 6
3 4 5 3
2 6 3
2 3 6
3 3 6 5

Sample Output:

0
0
2
1
1
2

Informação

Codeforces

Provedor Codeforces

Código CF722F

Tags

chinese remainder theoremdata structuresimplementationnumber theorytwo pointers

Submetido 0

BOUA! 0

Taxa de BOUA's 0%

Datas 09/05/2023 09:09:43

Relacionados

Nada ainda