#include <bits/stdc++.h>
using namespace std;
#define faster ios_base::sync_with_stdio(false); cin.tie(NULL)
#define Bit(mask , i) ((mask >> i) & 1)
#define fi first
#define se second
#define _LOG2(nl) 31 - __builtin_clz(nl)
#define c_bit(nl) __builtin_popcount(nl)
#define li pair<long long , int>
#define db double
#define onBit(mask , i) (mask | (1 << i))
#define offBit(mask , i) (mask & (~(1 << i)))
const long long MOD = 1e9 + 7;
const long long INF = 1e14;
const int N = 3e5 + 7;
int z[N] , kmp[N];
int s[N];
int n;
void inp(){
cin >> n;
for (int i = 1 ; i <= n ; ++i) cin >> s[i];
}
bool check(int k){
int i = 1;
while (i <= n){
if (z[i] < min(k , n - i + 1)) return 0;
i += k;
}
return 1;
}
void solve(){
// int k = kmp[1] = 0;
// for (int i = 2 ; i <= n ; ++i){
// while (k > 0 && s[i] != s[k + 1]) k = kmp[k];
// kmp[i] = s[i] == s[k + 1] ? ++k : 0;
// }
for (int i = 1 , l = 2 , r = 1 ; i <= n ; ++i){
if (i <= r)
z[i] = min(r - i + 1 , z[i - l + 1]);
while (i + z[i] <= n && s[1 + z[i]] == s[i + z[i]])
++z[i];
if (i + z[i] - 1 > r){
l = i;
r = i + z[i] - 1;
}
}
for (int i = 1 ; i <= n ; ++i){
if (check(i)){
cout << i;
return;
}
}
}
int main(){
// freopen("xhmax.inp" , "r" , stdin);
// freopen("xhmax.out" , "w" , stdout);
faster;
inp();
solve();
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgZmFzdGVyIGlvc19iYXNlOjpzeW5jX3dpdGhfc3RkaW8oZmFsc2UpOyBjaW4udGllKE5VTEwpCiNkZWZpbmUgQml0KG1hc2sgLCBpKSAoKG1hc2sgPj4gaSkgJiAxKQojZGVmaW5lIGZpIGZpcnN0CiNkZWZpbmUgc2Ugc2Vjb25kCiNkZWZpbmUgX0xPRzIobmwpIDMxIC0gX19idWlsdGluX2NseihubCkKI2RlZmluZSBjX2JpdChubCkgX19idWlsdGluX3BvcGNvdW50KG5sKQojZGVmaW5lIGxpIHBhaXI8bG9uZyBsb25nICwgaW50PgojZGVmaW5lIGRiIGRvdWJsZQojZGVmaW5lIG9uQml0KG1hc2sgLCBpKSAobWFzayB8ICgxIDw8IGkpKQojZGVmaW5lIG9mZkJpdChtYXNrICwgaSkgKG1hc2sgJiAofigxIDw8IGkpKSkKCmNvbnN0IGxvbmcgbG9uZyBNT0QgPSAxZTkgKyA3Owpjb25zdCBsb25nIGxvbmcgSU5GID0gMWUxNDsKY29uc3QgaW50IE4gPSAzZTUgKyA3OwppbnQgeltOXSAsIGttcFtOXTsKaW50IHNbTl07CmludCBuOwoKdm9pZCBpbnAoKXsKICAgIGNpbiA+PiBuOwogICAgZm9yIChpbnQgaSA9IDEgOyBpIDw9IG4gOyArK2kpIGNpbiA+PiBzW2ldOwp9Cgpib29sIGNoZWNrKGludCBrKXsKICAgIGludCBpID0gMTsKICAgIHdoaWxlIChpIDw9IG4pewogICAgICAgIGlmICh6W2ldIDwgbWluKGsgLCBuIC0gaSArIDEpKSByZXR1cm4gMDsKICAgICAgICBpICs9IGs7CiAgICB9CiAgICByZXR1cm4gMTsKfQoKdm9pZCBzb2x2ZSgpewovLyAgICBpbnQgayA9IGttcFsxXSA9IDA7Ci8vICAgIGZvciAoaW50IGkgPSAyIDsgaSA8PSBuIDsgKytpKXsKLy8gICAgICAgIHdoaWxlIChrID4gMCAmJiBzW2ldICE9IHNbayArIDFdKSBrID0ga21wW2tdOwovLyAgICAgICAga21wW2ldID0gc1tpXSA9PSBzW2sgKyAxXSA/ICsrayA6IDA7Ci8vICAgIH0KICAgIGZvciAoaW50IGkgPSAxICwgbCA9IDIgLCByID0gMSA7IGkgPD0gbiA7ICsraSl7CiAgICAgICAgaWYgKGkgPD0gcikKICAgICAgICAgICAgeltpXSA9IG1pbihyIC0gaSArIDEgLCB6W2kgLSBsICsgMV0pOwogICAgICAgIHdoaWxlIChpICsgeltpXSA8PSBuICYmIHNbMSArIHpbaV1dID09IHNbaSArIHpbaV1dKQogICAgICAgICAgICArK3pbaV07CiAgICAgICAgaWYgKGkgKyB6W2ldIC0gMSA+IHIpewogICAgICAgICAgICBsID0gaTsKICAgICAgICAgICAgciA9IGkgKyB6W2ldIC0gMTsKICAgICAgICB9CiAgICB9CiAgICBmb3IgKGludCBpID0gMSA7IGkgPD0gbiA7ICsraSl7CiAgICAgICAgaWYgKGNoZWNrKGkpKXsKICAgICAgICAgICAgY291dCA8PCBpOwogICAgICAgICAgICByZXR1cm47CiAgICAgICAgfQogICAgfQp9CgppbnQgbWFpbigpewovLwlmcmVvcGVuKCJ4aG1heC5pbnAiICwgInIiICwgc3RkaW4pOwovLwlmcmVvcGVuKCJ4aG1heC5vdXQiICwgInciICwgc3Rkb3V0KTsKICAgIGZhc3RlcjsKICAgIGlucCgpOwogICAgc29sdmUoKTsKICAgIHJldHVybiAwOwp9Cg==