Submission details
Task:Buzzwords
Sender:ind1f
Submission time:2025-11-03 17:07:22 +0200
Language:C++ (C++17)
Status:READY
Result:
Test results
testverdicttime
#10.00 sdetails
#20.00 sdetails
#30.00 sdetails
#40.00 sdetails
#50.00 sdetails
#60.00 sdetails
#70.00 sdetails
#80.00 sdetails
#90.00 sdetails
#100.00 sdetails
#110.00 sdetails
#120.00 sdetails
#130.00 sdetails
#140.00 sdetails
#150.00 sdetails
#160.00 sdetails
#170.00 sdetails
#180.00 sdetails
#190.00 sdetails
#200.00 sdetails
#210.00 sdetails
#220.00 sdetails
#230.00 sdetails
#240.00 sdetails
#250.00 sdetails
#260.00 sdetails
#270.00 sdetails
#280.00 sdetails
#290.00 sdetails
#300.00 sdetails
#310.00 sdetails
#320.00 sdetails
#330.00 sdetails
#340.00 sdetails
#350.00 sdetails
#360.00 sdetails
#370.00 sdetails
#380.00 sdetails
#390.00 sdetails
#400.00 sdetails
#410.01 sdetails
#420.08 sdetails
#430.07 sdetails
#440.01 sdetails

Compiler report

input/code.cpp: In function 'int main()':
input/code.cpp:61:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   61 |     for (int i = 0; i < t.size(); i++) {
      |                     ~~^~~~~~~~~~

Code

#include <iostream>

using namespace std;

const int N = 1e3 + 5;
const int P = 29;
const int MOD = 1e9 + 7;

void add(int &a, int b) {
  a += b;
  if (a >= MOD) {
    a -= MOD;
  }
}

void sub(int &a, int b) {
  a -= b;
  if (a < 0) {
    a += MOD;
  }
}

int mul(int a, int b) {
  return 1LL * a * b % MOD;
}

string s;
int n, q;
int a[N], h[N];
int pp[N];

int get(int l, int r) {
  if (l == 0) {
    return h[r];
  }
  int ans = h[r];
  sub(ans, mul(h[l - 1], pp[r - l + 1]));
  return ans;
}

int main() {
  ios::sync_with_stdio(false);
  cin.tie(0);
  pp[0] = 1;
  for (int i = 1; i < N; i++) {
    pp[i] = mul(P, pp[i - 1]);
  }
  getline(cin, s);
  n = s.size();
  for (int i = 0; i < n; i++) {
    a[i] = (a[i] == ' ' ? 26 : (a[i] - 'a'));
    h[i] = (i == 0 ? a[i] : mul(h[i - 1], P) + a[i]);
    h[i] %= MOD;
  }
  cin >> q;
  int ans = 0;
  while (q--) {
    string t;
    getline(cin, t);
    int z = 0;
    for (int i = 0; i < t.size(); i++) {
      int b = (t[i] == ' ' ? 26 : t[i] - 'a');
      z = mul(z, P);
      add(z, b);
    }
    for (int i = 0; i + t.size() - 1 < s.size(); i++) {
      ans += (z == get(i, i + t.size() - 1));
    }
  }
  cout << ans << '\n';
  return 0;
}

Test details

Test 1

Verdict:

input
g fhe
395
a
aa
aafh
...

correct output
10

user output
0

Test 2

Verdict:

input
s adh
372
a
ad
ae
...

correct output
6

user output
0

Test 3

Verdict:

input
adcdb
20
a
aa
ab
...

correct output
9

user output
0

Test 4

Verdict:

input
aaaaa
5
a
aa
aaa
...

correct output
15

user output
0

Test 5

Verdict:

input
o zws
759
a
ab
abw
...

correct output
8

user output
0

Test 6

Verdict:

input
aaaaa
5
a
aa
aaa
...

correct output
15

user output
0

Test 7

Verdict:

input
ifv b
649
a
aaw
ac
...

correct output
10

user output
0

Test 8

Verdict:

input
dbbdc
129
a
aa
aaab
...

correct output
15

user output
0

Test 9

Verdict:

input
aaaaa
5
a
aa
aaa
...

correct output
15

user output
0

Test 10

Verdict:

input
eeeab
9
a
b
c
...

correct output
5

user output
0

Test 11

Verdict:

input
ghfhe d fd
430
a
aa
aafa
...

correct output
22

user output
0

Test 12

Verdict:

input
syadhzdgck
275
a
ad
adh
...

correct output
53

user output
0

Test 13

Verdict:

input
adcdbbbbba
256
a
aa
aaa
...

correct output
49

user output
0

Test 14

Verdict:

input
aaaaaaaaaa
10
a
aa
aaa
...

correct output
55

user output
0

Test 15

Verdict:

input
o zwspspfd
468
a
adks
afhsrhvwxn
...

correct output
45

user output
0

Test 16

Verdict:

input
aaaaaaaaaa
10
a
aa
aaa
...

correct output
55

user output
0

Test 17

Verdict:

input
i vbbjczpc
703
a
aa
abou
...

correct output
29

user output
0

Test 18

Verdict:

input
d bdcbdbcb
128
a
aa
aab
...

correct output
42

user output
0

Test 19

Verdict:

input
aaaaaaaaaa
10
a
aa
aaa
...

correct output
55

user output
0

Test 20

Verdict:

input
eeeabcbabh
171
a
aac
aahg
...

correct output
34

user output
0

Test 21

Verdict:

input
ghfhehdf ddciaicdehheefdihadaf...

correct output
246

user output
0

Test 22

Verdict:

input
s adhzdgckekirkyowkirnflwfanrx...

correct output
52

user output
0

Test 23

Verdict:

input
adcdbbbbbaaccabbbccd cabccacdb...

correct output
178

user output
0

Test 24

Verdict:

input
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa...

correct output
2518

user output
0

Test 25

Verdict:

input
oezws spfdzfasgxlquafowjzpe pv...

correct output
284

user output
0

Test 26

Verdict:

input
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa...

correct output
1387

user output
0

Test 27

Verdict:

input
ifvbbjczpcnpknimqvlttkngpe szx...

correct output
258

user output
0

Test 28

Verdict:

input
dbbdcbdb bcaabb bccddbbbacbcdc...

correct output
36

user output
0

Test 29

Verdict:

input
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa...

correct output
3076

user output
0

Test 30

Verdict:

input
e eabcbabhdbcbaddebchdiga ggfb...

correct output
23

user output
0

Test 31

Verdict:

input
ghfhehdff dci icdehheefdih daf...

correct output
248

user output
0

Test 32

Verdict:

input
s a hzdgckekirkyo kirnflw anrx...

correct output
27

user output
0

Test 33

Verdict:

input
adcdbbb baac abbbcc c abccacd ...

correct output
433

user output
0

Test 34

Verdict:

input
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa...

correct output
3427

user output
0

Test 35

Verdict:

input
oezwsp pf z asgxlquafowjzpekpv...

correct output
359

user output
0

Test 36

Verdict:

input
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa...

correct output
2126

user output
0

Test 37

Verdict:

input
ifvbbjczpcnpk imqvlttkngpeqszx...

correct output
395

user output
0

Test 38

Verdict:

input
dbbdcbd cbcaabbabccddbb acbcdc...

correct output
242

user output
0

Test 39

Verdict:

input
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa...

correct output
4287

user output
0

Test 40

Verdict:

input
eeeabcbabhd cb ddebchdigaiggfb...

correct output
15

user output
0

Test 41

Verdict:

input
ghfhehdffdd i icdehheefd hadaf...

correct output
431

user output
0

Test 42

Verdict:

input
syadhzdgckekirkyow irnflwfanrx...

correct output
8039

user output
0

Test 43

Verdict:

input
adcdbbbbbaaccabb ccdccabcc cdb...

correct output
9409

user output
0

Test 44

Verdict:

input
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa...

correct output
168696

user output
0