#include <cstdio>
#include <cstring>
#include <cassert>
using namespace std;
#define forn(i, n) for (int i = 0; i < n; i++)
template <const int N = 250000>
struct SuffixArray {
int p[N], p2[N]; // p2 * p = id
int len[N]; // LCP
template <class T>
void BuildArray( int n, T *s ) { // O(NlogN)
static int num[N + 1], col[N];
int ma = n, t, cc = 0;
forn(i, n)
ma = max(ma, t = s[i]), assert(0 <= t && t < N);
forn(i, n)
col[i] = s[i], p[i] = i;
for (int k2 = 1; k2 / 2 < n && cc != n - 1; k2 *= 2) {
int k = k2 / 2;
memset(num, 0, sizeof(num[0]) * (ma + 1));
forn(i, n)
num[col[i] + 1]++;
forn(i, ma)
num[i + 1] += num[i];
forn(i, n)
p2[num[col[(p[i] - k + n) % n]]++] = (p[i] - k + n) % n;
cc = 0;
forn(i, n) {
cc += (i && (col[p2[i]] != col[p2[i - 1]] || col[(p2[i] + k) % n] != col[(p2[i - 1] + k) % n]));
num[p2[i]] = cc;
}
forn(i, n)
p[i] = p2[i], col[i] = num[i];
}
forn(i, n)
p2[p[i]] = i;
}
template <class T>
void BuildLCP( int n, T *s ) { // O(N), works only for s with no nontrivial period
int lcp = 0;
forn(i, n) {
int j = p2[i];
if (--lcp < 0)
lcp = 0;
if (j != n - 1)
while (lcp < n && s[(p[j] + lcp) % n] == s[(p[j + 1] + lcp) % n])
lcp++;
len[j] = lcp;
}
}
};