QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#589177#7876. Cyclic SubstringslimpidAC ✓525ms923816kbC++141.5kb2024-09-25 16:33:212024-09-25 16:33:21

Judging History

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

  • [2024-09-25 16:33:21]
  • 评测
  • 测评结果:AC
  • 用时:525ms
  • 内存:923816kb
  • [2024-09-25 16:33:21]
  • 提交

answer

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#define LL long long
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define mod 998244353
using namespace std;
inline int read(){
    int f=1,ans=0; char c=getchar();
    while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
    while(c>='0'&&c<='9'){ans=ans*10+c-'0';c=getchar();}
    return f*ans;
}
const int MAXN = 6e6 + 11;
int ch[MAXN][10], cnt, tot, fail[MAXN], lst, len[MAXN], siz[MAXN];
int node(int l){cnt++; len[cnt] = l; return cnt;}
char str[MAXN];
vector<int> vec[MAXN];
void Init(){
	cnt = -1; str[0] = '&'; 
	node(0), node(-1); fail[0] = 1;
	lst = 0;
}
int getfail(int x, char c){
	while(str[tot - len[x] - 1] != c){
		x = fail[x];
	}
	return x;
}
int N;
int ret;
void ins(char c, int id){
	tot++; int now = getfail(lst, c);
	if(!ch[now][c - '0']){
		int x = node(len[now] + 2);
		fail[x] = ch[getfail(fail[now], c)][c - '0'];
		ch[now][c - '0'] = x;
	}lst = ch[now][c - '0']; 
	if(id > N) siz[lst]++;
}
void dfs(int u){
	for(auto v: vec[u]) dfs(v), siz[u] += siz[v];
	if(len[u] <= N && len[u] >= 1) ret += 1ll * siz[u] * siz[u] % mod * len[u] % mod, ret %= mod;
	return;
}
signed main(){
	N = read(); Init();
	scanf("%s", str + 1); for(int i = N + 1; i <= 2 * N; i++) str[i] = str[i - N];
	for(int i = 1; i <= 2 * N; i++) ins(str[i], i);
	for(int i = 0; i <= cnt; i++) if(i != 1) vec[fail[i]].pb(i);
	dfs(1);
	printf("%d\n", ret);
}

这程序好像有点Bug,我给组数据试试?

詳細信息

Test #1:

score: 100
Accepted
time: 30ms
memory: 153800kb

input:

5
01010

output:

39

result:

ok 1 number(s): "39"

Test #2:

score: 0
Accepted
time: 16ms
memory: 153404kb

input:

8
66776677

output:

192

result:

ok 1 number(s): "192"

Test #3:

score: 0
Accepted
time: 32ms
memory: 154436kb

input:

1
1

output:

1

result:

ok 1 number(s): "1"

Test #4:

score: 0
Accepted
time: 23ms
memory: 153420kb

input:

2
22

output:

12

result:

ok 1 number(s): "12"

Test #5:

score: 0
Accepted
time: 15ms
memory: 152988kb

input:

2
21

output:

2

result:

ok 1 number(s): "2"

Test #6:

score: 0
Accepted
time: 19ms
memory: 153180kb

input:

3
233

output:

10

result:

ok 1 number(s): "10"

Test #7:

score: 0
Accepted
time: 27ms
memory: 152852kb

input:

3
666

output:

54

result:

ok 1 number(s): "54"

Test #8:

score: 0
Accepted
time: 119ms
memory: 412060kb

input:

1000000
3333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333...

output:

496166704

result:

ok 1 number(s): "496166704"

Test #9:

score: 0
Accepted
time: 343ms
memory: 923816kb

input:

3000000
2222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222...

output:

890701718

result:

ok 1 number(s): "890701718"

Test #10:

score: 0
Accepted
time: 165ms
memory: 368364kb

input:

3000000
9999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999...

output:

224009870

result:

ok 1 number(s): "224009870"

Test #11:

score: 0
Accepted
time: 366ms
memory: 783168kb

input:

3000000
8989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989898989...

output:

51985943

result:

ok 1 number(s): "51985943"

Test #12:

score: 0
Accepted
time: 369ms
memory: 736320kb

input:

3000000
1911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911911...

output:

355676465

result:

ok 1 number(s): "355676465"

Test #13:

score: 0
Accepted
time: 210ms
memory: 569860kb

input:

3000000
7777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777777...

output:

788510374

result:

ok 1 number(s): "788510374"

Test #14:

score: 0
Accepted
time: 248ms
memory: 549284kb

input:

3000000
5555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555...

output:

691884476

result:

ok 1 number(s): "691884476"

Test #15:

score: 0
Accepted
time: 525ms
memory: 362884kb

input:

3000000
0990990909909909099090990990909909909099090990990909909099099090990990909909099099090990990909909099099090990909909909099099090990909909909099090990990909909909099090990990909909909099090990990909909099099090990990909909099099090990990909909099099090990909909909099099090990909909909099090990...

output:

701050848

result:

ok 1 number(s): "701050848"

Test #16:

score: 0
Accepted
time: 178ms
memory: 214760kb

input:

3000000
2772772727727727277272772772727727727277272772772727727277277272772772727727277277272772772727727277277272772727727727277277272772727727727277272772772727727727277272772772727727727277272772772727727277277272772772727727277277272772772727727277277272772727727727277277272772727727727277272772...

output:

486861605

result:

ok 1 number(s): "486861605"

Test #17:

score: 0
Accepted
time: 513ms
memory: 488348kb

input:

3000000
4554554545545545455454554554545545545455454554554545545455455454554554545545455455454554554545545455455454554545545545455455454554545545545455454554554545545545455454554554545545545455454554554545545455455454554554545545455455454554554545545455455454554545545545455455454554545545545455454554...

output:

450625621

result:

ok 1 number(s): "450625621"

Test #18:

score: 0
Accepted
time: 508ms
memory: 478120kb

input:

3000000
1181811811818118181181181811818118118181181181811818118118181181181811818118118181181811811818118118181181811811818118181181181811811818118181181181811811818118181181181811818118118181181181811818118118181181181811818118118181181811811818118118181181811811818118181181181811811818118181181181...

output:

649551870

result:

ok 1 number(s): "649551870"

Extra Test:

score: 0
Extra Test Passed