Pagini recente » Cod sursa (job #267052) | Cod sursa (job #1747175) | Cod sursa (job #3292235) | Cod sursa (job #182034) | Cod sursa (job #3292221)
#include<fstream>
#include<string>
#include<vector>
const std::string txt="strmatch";
std::ifstream cin(txt+".in");
std::ofstream cout(txt+".out");
std::string a,b;
std::vector <int> v;
int u[4000005];
signed main(int n,int m,int j){
cin>>a>>b;
b=a+" "+b;
n=a.size();
m=b.size();
j=0;
for(int i=1;i<m;++i){
while(j>0 && b[j]!=b[i])
j=u[j-1];
if(b[j]==b[i])
++j;
u[i]=j;
if(u[i]==n)
v.push_back(i-n);
}
cout<<v.size()<<'\n';
for(auto i:v)
cout<<i-n<<' ';
}