Pagini recente » Cod sursa (job #3217258) | Cod sursa (job #1521196) | Cod sursa (job #2933139) | Cod sursa (job #3216980) | Cod sursa (job #2297028)
#include <fstream>
#include <string>
#include <cstring>
#include <map>
#include <set>
using namespace std;
ifstream in("abc2.in");
ofstream out("abc2.out");
int cnt, n, len, ans;
char ch[10000001];
string cuv[50001];
map<string, int> us;
set<string> frecv;
int main()
{
in >> ch;
while(!in.eof())
in >> cuv[cnt++];
n = cuv[0].length();
len = strlen(ch);
for(int i = 0; i < len - n + 1; i++)
{
char temp[21] = {'\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0'};
for(int j = 0; j < n; j++)
temp[j] = ch[i+j];
string str(temp);
us[str]++;
}
for(int i = 0; i < cnt; i++)
{
if(frecv.count(cuv[i]) == 0)
{
ans += us[cuv[i]];
frecv.insert(cuv[i]);
}
}
out << ans;
return 0;
}