Pagini recente » Cod sursa (job #3319703) | Cod sursa (job #3338455) | Cod sursa (job #3330215) | Cod sursa (job #3338668) | Cod sursa (job #3338446)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("abc2.in");
ofstream fout("abc2.out");
long long n,i,j,x,op,h1,h2,p=1,sol;
string a,b;
unordered_map<long long ,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;
}