Pagini recente » Clasament preONI 2007, Runda 1, Clasa a 10-a | Cod sursa (job #298975) | Cod sursa (job #488) | Cod sursa (job #3288727) | Cod sursa (job #3292220)
#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[((int)1e6)*4+5];
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<<' ';
}