|시간 제한||메모리 제한||제출||정답||맞은 사람||정답 비율|
|5 초||128 MB||12||4||4||36.364%|
A word t is called a period of the word s if it is not longer than s and there exists a natural number k such that s is a prefix of tk. E.g., the periods of the word entente are: ent, entent and entente.
The teacher wrote a very long word on the whiteboard. Bytie was not really interested in what was the class about but he wrote down in his notebook all the words that can be obtained from the word on the whiteboard by removing exactly one letter. Now he would like to choose the word in his list with the shortest shortest period. Write a program that will help him with this problem.
The first line of the standard input contains one integer d (1 ≤ d ≤ 10), the number of test cases. d lines follow, each of them contains one integer ni (2 ≤ ni ≤ 200,000) that denotes the length of the word on the whiteboard and a ni-letter word composed of small English letters.
Your program should write d lines to the standard output. The i-th line should contain the answer for the i-th test case: one integer equal to the length of the shortest period among all the shortest periods of the words written in Bytie's notebook.
1 8 ababcaba
Explanation of the example: Here are the words written by Bytie, together with the length of their shortest periods:
We see that removing the letter c at the fifth position of the word produces a word with the shortest period of length 2 and removing no other letter gives a word with a shorter shortest period.