This documentation is automatically generated by online-judge-tools/verification-helper
// verification-helper: PROBLEM http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=ALDS1_14_B
#include<bits/stdc++.h>
using namespace std;
#define call_from_test
#include "../../string/knuthmorrispratt.cpp"
#undef call_from_test
signed main(){
cin.tie(0);
ios::sync_with_stdio(0);
string t,p;
cin>>t>>p;
vector<int> res=pattern_match(p,t);
for(int x:res) cout<<x<<"\n";
cout<<flush;
return 0;
}
#line 1 "test/aoj/ALDS1_14_B.knuthmorrispratt.test.cpp"
// verification-helper: PROBLEM http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=ALDS1_14_B
#include<bits/stdc++.h>
using namespace std;
#define call_from_test
#line 1 "string/knuthmorrispratt.cpp"
#line 3 "string/knuthmorrispratt.cpp"
using namespace std;
#endif
// https://snuke.hatenablog.com/entry/2017/07/18/101026
//BEGIN CUT HERE
vector<int> knuth_morris_pratt(const string &s){
int n=s.size();
vector<int> kmp(n+1,-1);
for(int i=0,j=-1;i<n;i++){
while(~j and s[i]!=s[j]) j=kmp[j];
kmp[i+1]=++j;
if(i+1<n and s[i+1]==s[j]) kmp[i+1]=kmp[j];
}
return kmp;
}
// positions for t that match s
vector<int> pattern_match(string s,string t){
int n=s.size(),m=t.size();
vector<int> kmp=knuth_morris_pratt(s);
vector<int> res;
int i=0,j=0;
while(i+j<m){
if(s[j]==t[i+j]){
if(++j!=n) continue;
res.emplace_back(i);
}
i+=j-kmp[j];
j=max(kmp[j],0);
}
return res;
}
//END CUT HERE
#ifndef call_from_test
template<typename T1,typename T2> inline void chmin(T1 &a,T2 b){if(a>b) a=b;}
template<typename T1,typename T2> inline void chmax(T1 &a,T2 b){if(a<b) a=b;}
//INSERT ABOVE HERE
// test knuth_morris_pratt
signed ABC135_F(){
cin.tie(0);
ios::sync_with_stdio(0);
string s,t;
cin>>s>>t;
int n=s.size(),m=t.size();
string b;
while(b.size()<t.size()) b+=s;
auto kmp=knuth_morris_pratt(t+'$'+b+b);
vector<int> match(n);
for(int i=m+1;i<=m+n;i++)
match[i-(m+1)]=kmp[i+m]==m;
vector< vector<int> > G(n);
for(int i=0;i<n;i++)
if(match[i]) G[i].emplace_back((i+m)%n);
vector<int> indeg(n,0);
for(int i=0;i<n;i++)
for(int j:G[i]) indeg[j]++;
queue<int> que;
for(int i=0;i<n;i++)
if(indeg[i]==0) que.emplace(i);
vector<int> dp(n,0);
while(!que.empty()){
int v=que.front();que.pop();
for(int u:G[v]){
chmax(dp[u],dp[v]+1);
indeg[u]--;
if(indeg[u]==0) que.emplace(u);
}
}
for(int i=0;i<n;i++){
if(indeg[i]!=0){
cout<<-1<<endl;
return 0;
}
}
cout<<*max_element(dp.begin(),dp.end())<<endl;
return 0;
}
/*
verified on 2020/08/20
https://atcoder.jp/contests/abc135/tasks/abc135_f
*/
signed main(){
ABC135_F();
return 0;
}
#endif
#line 8 "test/aoj/ALDS1_14_B.knuthmorrispratt.test.cpp"
#undef call_from_test
signed main(){
cin.tie(0);
ios::sync_with_stdio(0);
string t,p;
cin>>t>>p;
vector<int> res=pattern_match(p,t);
for(int x:res) cout<<x<<"\n";
cout<<flush;
return 0;
}