QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#276044#5065. Beautiful StringrageOfThunder#TL 1ms3916kbC++141.1kb2023-12-05 15:20:252023-12-05 15:20:25

Judging History

你现在查看的是最新测评结果

  • [2023-12-05 15:20:25]
  • 评测
  • 测评结果:TL
  • 用时:1ms
  • 内存:3916kb
  • [2023-12-05 15:20:25]
  • 提交

answer

#include <bits/stdc++.h>

using namespace std;

using ll = long long;

const int mod = 1e9 + 9;

const int N = 5e3;
const int B = 131;

int n;
char s[N + 5];
int pw[N + 5], h[N + 5];
int f[N + 5][N + 5];
unordered_map<int, int> cnt;
int query(int l, int r) { return (h[r] + (ll)(mod - pw[r - l + 1]) * h[l - 1]) % mod; }
ll ans;

void solve() {
  scanf("%s", s + 1), n = strlen(s + 1);
  pw[0] = 1;
  for (int i = 1; i <= n; ++i) pw[i] = (ll)pw[i - 1] * B % mod;
  for (int i = 1; i <= n; ++i) h[i] = ((ll)h[i - 1] * B + s[i] - '0' + 1) % mod;
  cnt.clear();
  for (int i = n; i; --i) {
    for (int j = i - 1; j; --j) f[j][i - 1] = cnt[query(j, i - 1)];
    for (int j = i; j <= n; ++j) ++cnt[query(i, j)];
  }
  ans = 0;
  for (int i = 1; i <= n; ++i) {
    int cur = 0;
    for (int len = 1; i + len - 1 <= n; ++len) {
      ans += (ll)cur * f[i][i + len - 1];
      if (len <= i - 1 && query(i - len, i - 1) == query(i, i + len - 1)) ++cur;
    }
  }
  printf("%d\n", ans);
}

int T;

int main() {
  for (scanf("%d", &T); T; --T) solve();
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 3916kb

input:

2
114514
0000000

output:

1
3

result:

ok 2 number(s): "1 3"

Test #2:

score: -100
Time Limit Exceeded

input:

11
79380
2483905227
37902399703986576270
39991723655814713848046032694137883815354365954917
5541883522667841718787744915558298207485830622522715211018760095628594390563630840464643840093757297
56530485554219245862513973750218715585679416120445975390556326891488719311495909340757506478400624741858999...

output:


result: