This documentation is automatically generated by online-judge-tools/verification-helper
#ifndef call_from_test
#include <bits/stdc++.h>
using namespace std;
#endif
// https://snuke.hatenablog.com/entry/2014/12/01/235807
// https://kopricky.github.io/code/String/kmp.html
//BEGIN CUT HERE
// longest prefix suffix matching of [0, i)
vector<int> morris_pratt(const string &s){
int n=s.size();
vector<int> mp(n+1,-1);
for(int i=0,j=-1;i<n;i++){
while(~j and s[i]!=s[j]) j=mp[j];
mp[i+1]=++j;
}
return mp;
}
// smallest d s.t. s[x] == s[x + d] for all x
vector<int> minimum_period(const string &s){
auto mp=morris_pratt(s);
for(int i=1;i<(int)mp.size();i++) mp[i]=i-mp[i];
return mp;
}
//END CUT HERE
#ifndef call_from_test
//INSERT ABOVE HERE
// test minimum_period
signed ARC060_F(){
cin.tie(0);
ios::sync_with_stdio(0);
string w;
cin>>w;
int n=w.size();
if(w==string(n,w[0])){
cout<<n<<endl<<1<<endl;
return 0;
}
auto kmp=minimum_period(w);
if(n%kmp[n]!=0 or n==kmp[n]){
cout<<1<<endl<<1<<endl;
return 0;
}
string w_rev=w;
reverse(w_rev.begin(),w_rev.end());
auto kmp_rev=minimum_period(w_rev);
int cnt=0;
for(int i=1;i<n;i++){
int j=n-i;
if(i%kmp[i]==0 and i>kmp[i]) continue;
if(j%kmp_rev[j]==0 and j>kmp_rev[j]) continue;
cnt++;
}
cout<<2<<endl<<cnt<<endl;
return 0;
}
/*
verified on 2020/08/20
https://atcoder.jp/contests/arc060/tasks/arc060_d
*/
signed main(){
ARC060_F();
return 0;
}
#endif
#line 1 "string/morrispratt.cpp"
#include <bits/stdc++.h>
using namespace std;
#endif
// https://snuke.hatenablog.com/entry/2014/12/01/235807
// https://kopricky.github.io/code/String/kmp.html
//BEGIN CUT HERE
// longest prefix suffix matching of [0, i)
vector<int> morris_pratt(const string &s){
int n=s.size();
vector<int> mp(n+1,-1);
for(int i=0,j=-1;i<n;i++){
while(~j and s[i]!=s[j]) j=mp[j];
mp[i+1]=++j;
}
return mp;
}
// smallest d s.t. s[x] == s[x + d] for all x
vector<int> minimum_period(const string &s){
auto mp=morris_pratt(s);
for(int i=1;i<(int)mp.size();i++) mp[i]=i-mp[i];
return mp;
}
//END CUT HERE
#ifndef call_from_test
//INSERT ABOVE HERE
// test minimum_period
signed ARC060_F(){
cin.tie(0);
ios::sync_with_stdio(0);
string w;
cin>>w;
int n=w.size();
if(w==string(n,w[0])){
cout<<n<<endl<<1<<endl;
return 0;
}
auto kmp=minimum_period(w);
if(n%kmp[n]!=0 or n==kmp[n]){
cout<<1<<endl<<1<<endl;
return 0;
}
string w_rev=w;
reverse(w_rev.begin(),w_rev.end());
auto kmp_rev=minimum_period(w_rev);
int cnt=0;
for(int i=1;i<n;i++){
int j=n-i;
if(i%kmp[i]==0 and i>kmp[i]) continue;
if(j%kmp_rev[j]==0 and j>kmp_rev[j]) continue;
cnt++;
}
cout<<2<<endl<<cnt<<endl;
return 0;
}
/*
verified on 2020/08/20
https://atcoder.jp/contests/arc060/tasks/arc060_d
*/
signed main(){
ARC060_F();
return 0;
}
#endif