Pagini recente » Cod sursa (job #3304032) | Cod sursa (job #3343568) | Cod sursa (job #3347613) | Cod sursa (job #3325812) | Cod sursa (job #3338449)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("abc2.in");
ofstream fout("abc2.out");
int n,i,j,x,op,h1,h2,p=1,sol;
string a,b;
unordered_map<int ,int> fr;
int main()
{ fin>>a;
fin>>b;
n=b.size();
for(i=0;i<n;i++)
{h1=h1*3+a[i]-'a';
if(i!=0) p*=3;
}
fr[h1]++;
for(i=n;i<a.size();i++)
{h1=h1-p*(a[i-n]-'a');
h1*=3;
h1+=a[i]-'a';
fr[h1]++;
}
for(i=0;i<b.size();i++)
h2=h2*3+b[i]-'a';
sol+=fr[h2];
fr[h2]=0;
while(fin>>b)
{h2=0;
for(i=0;i<b.size();i++)
h2=h2*3+b[i]-'a';
sol+=fr[h2];
fr[h2]=0;
}
fout<<sol;
return 0;
}