Pagini recente » Cod sursa (job #3165314) | Cod sursa (job #3004014) | Cod sursa (job #1586622) | Cod sursa (job #2779280) | Cod sursa (job #2770288)
/**
____ ____ ____ ____ ____
||O |||M |||E |||G |||A ||
||__|||__|||__|||__|||__||
|/__\|/__\|/__\|/__\|/__\|
Se spune ca sunt vise
Si ca nu pot fi atinse
Sunt primele ce le vezi cand becurile-s stinse
Dar si cand is aprinse
Cand te trezesti cu ele-n gand
Si le vizualizezi din nou rand pe rand
Se spune ca visezi daca stai si-ti imaginezi
Ca esti altfel decat ceilalti, dar nu tre sa crezi
Continua sa lupti altfel imi vei da dreptate
Vei bea pe spate cu gandul la vise spulberate
- "Vise" - Nane -
Тяжело стать богатым, но тяжелее остаться.
**/
#include<bits/stdc++.h>
using namespace std;
ifstream fin("strmatch.in");
ofstream fout("strmatch.out");
char a[2000005],b[2000005];
int x[2000005],v[2000005],k;
int main(){
fin>>(a+1)>>(b+1);
int n(strlen(a+1)),m(strlen(b+1));
int p(1);
for(int i=2;i<=n;i++){
if(a[i]==a[p])x[i]=x[i-1]+1,p++;
else p=x[p-1]+1;
}
p=1;
for(int i=1;i<=m;i++){
if(b[i]==a[p]){
p++;
if(p>n){
v[++k]=i-n;
p=x[n]+1;
}
}
else{
p=x[p-1]+1;
}
}
fout<<k<<"\n";
for(int i=1;i<=k;i++)fout<<v[i]<<" ";
return 0;
}