Pagini recente » Cod sursa (job #3225846) | Cod sursa (job #876530) | Cod sursa (job #1787729) | Cod sursa (job #2169130) | Cod sursa (job #2554574)
#include <bits/stdc++.h>
using namespace std;
ifstream f("strmatch.in");
ofstream g("strmatch.out");
vector <int> v;
char a[200001], b[2000001];
int q;
int main()
{
f >> a;
int m = strlen(a);
f.get();
f >> b;
int n = strlen(b);
for(int i = 0; i < n; ++ i)
if(b[i] == a[q])
{
q ++;
if(q == m)
{
v.push_back(i - m + 1);
q = 0;
if(b[i] == a[q]) q ++;
}
}
else q = 0;
g << v.size() << "\n";
for(int i = 0; i < v.size(); ++ i)
g << v[i] << " ";
return 0;
}