QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#392896#6419. Baby's First Suffix Array ProblemDiuTL 1458ms16208kbC++144.1kb2024-04-17 21:55:162024-04-17 21:55:16

Judging History

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

  • [2024-04-17 21:55:16]
  • 评测
  • 测评结果:TL
  • 用时:1458ms
  • 内存:16208kb
  • [2024-04-17 21:55:16]
  • 提交

answer

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=5e4+10;
int _,n,m;
int rk[N],sa[N],hei[N];
char s[N];
namespace SA{
	int m,x[N],y[N],c[N],mn[N][18],lg[N];
	bool cmp(int i,int j){
		while(i<=n&&j<=n){
			if(s[i]!=s[j])return s[i]<s[j];
			++i,++j;
		}
		return i>j;
	}
	void get_sa(){
		for(int i=1;i<=n;i++)sa[i]=i;
		sort(sa+1,sa+n+1,cmp);
//		m=131;
//		memset(sa,0,(n+1)*sizeof(int));
//		memset(y,0,(n+1)*sizeof(int));
//		memset(x,0,(n+1)*sizeof(int));
//		memset(c,0,max(m+1,n+1)*sizeof(int));
//		for(int i=1;i<=n;i++)c[x[i]=s[i]]++;
//		int l=0;
//		for(int i=1;i<=m;i++)c[i]+=c[i-1];
//		for(int i=n;i>=1;i--)sa[c[s[i]]--]=i;
//		for(int k=1;k<=n;k<<=1){
//			int num=0;
//			for(int i=n-k+1;i<=n;i++)y[++num]=i;
//			for(int i=1;i<=n;i++)if(sa[i]>k)y[++num]=sa[i]-k;
//			for(int i=1;i<=m;i++)c[i]=0;
//			for(int i=1;i<=n;i++)c[x[i]]++;
//			for(int i=2;i<=m;i++)c[i]+=c[i-1];
//			for(int i=n;i>=1;i--)sa[c[x[y[i]]]--]=y[i],y[i]=0;
//			swap(x,y);
//			num=1,x[sa[1]]=1;
//			for(int i=2;i<=n;i++){
//				if(y[sa[i]]==y[sa[i-1]]&&y[sa[i]+k]==y[sa[i-1]+k])x[sa[i]]=num;
//				else x[sa[i]]=++num; 
//			}
//			if(num==n)break;
//			m=num;
//		}
		for(int i=1;i<=n;i++)rk[sa[i]]=i;
		for(int i=1,k=0;i<=n;i++){
			int j=sa[rk[i]-1];k-=(k!=0);
			while(s[i+k]==s[j+k])++k;
			hei[rk[i]]=k;
		}
		for(int i=2;i<=n;i++)lg[i]=lg[i>>1]+1;
		for(int i=1;i<=n;i++){
			mn[i][0]=hei[i];
			for(int j=1;i>>j;j++)mn[i][j]=min(mn[i][j-1],mn[i-(1<<j-1)][j-1]);
		}
	}
	int lcp(int l,int r){
		l=rk[l],r=rk[r];
		if(l>r)swap(l,r);++l;
		int d=lg[r-l+1];
		return min(mn[r][d],mn[l+(1<<d)-1][d]);
	}
}
using SA::lcp;
struct Bit{
	int vis[N],st[N],tp,c[N];
	void ins(int i,int v){
		for(;i<=n;i+=i&-i){
			if(!vis[i])vis[i]=1,st[++tp]=i;
			c[i]+=v;
		}
	}
	int qry(int i){
		int s=0;
		for(;i;i&=i-1)s+=c[i];
		return s;
	}
	void clr(){
		for(;tp;--tp)vis[st[tp]]=c[st[tp]]=0;
	}
}T;
struct que{
	int l,r,i;
	bool operator<(const que h)const{return r<h.r;}
}ql[N],qr[N];
vector<que> q1[N],q2[N];
int ans[N];
namespace Conquer{
	int s[N];
	void solve(int l,int r){
		if(l==r)return;
		int mid=l+r>>1;solve(l,mid),solve(mid+1,r);
		s[mid]=s[mid+1]=hei[mid+1];
		for(int i=mid-1;i>=l;i--)s[i]=min(s[i+1],hei[i+1]);
		for(int i=mid+2;i<=r;i++)s[i]=min(s[i-1],hei[i]);
//		for(int i=l;i<=mid;i++)for(que t:q1[i]){
//			for(int j=mid+1;j<=r;j++){
//				if(sa[j]>t.l&&sa[j]<=t.r&&min(s[i],s[j])>=t.r-sa[j]+1)++ans[t.i];
//			}
//		}
//		return;
		int tl=0,tr=0;
		for(int i=mid;i>=l;i--){
			for(que t:q1[i]){
				int L=max(t.l+1,t.r-s[i]+1),R=t.r;
				if(L<=R)ql[++tl]={L,R,t.i};
			}
		}
		for(int i=mid+1;i<=r;i++)qr[++tr]={sa[i],sa[i]+s[i],i};
		sort(ql+1,ql+tl+1),sort(qr+1,qr+tr+1);
		int p=tr;
		for(int i=tl;i>=1;i--){
			while(p&&qr[p].r>ql[i].r)T.ins(qr[p].l,1),--p;
			ans[ql[i].i]+=T.qry(ql[i].r)-T.qry(ql[i].l-1);
		}
		T.clr();
	}
}
signed main(){
//	freopen("str.in","r",stdin);
//	freopen("str.out","w",stdout);
	scanf("%d",&_);
	for(;_--;){
		scanf("%d%d\n%s",&n,&m,s+1);
		SA::get_sa();
//		for(int i=1;i<=n;i++)printf("%d ",sa[i]);puts("");
//		for(int i=1;i<=n;i++)printf("%d ",rk[i]);puts("");
//		for(int i=1;i<=n;i++)printf("%d ",hei[i]);puts("");
		for(int i=1;i<=n;i++)q1[i].clear(),q2[i].clear(); 
		for(int i=1,l,r,k;i<=m;i++){
			scanf("%d%d%d",&l,&r,&k),ans[i]=1;
			int L=0,R=rk[k];
			while(L+1<R){
				int mid=L+R>>1;
				if(lcp(k,sa[mid])>=r-k+1)R=mid;
				else L=mid;
			}
			if(k>l)q2[L].push_back({l,k-1,i});
			if(k<r)q2[rk[k]].push_back({k+1,r,i}),q1[rk[k]].push_back({k,r,i});
//			for(int j=l;j<k;j++)if(rk[j]<rk[k]&&lcp(j,k)<r-k+1)++ans[i];
//			for(int j=k+1;j<=r;j++)if(rk[j]<rk[k])++ans[i];
//			for(int j=k+1;j<=r;j++)if(rk[j]>rk[k]&&lcp(j,k)>=r-j+1)++ans[i];
		}
		for(int i=1;i<=n;i++){
			T.ins(sa[i],1);
			for(que t:q2[i])ans[t.i]+=T.qry(t.r)-T.qry(t.l-1);
		}
		T.clr();
		Conquer::solve(1,n);
		for(int i=1;i<=m;i++)printf("%d\n",ans[i]);
	}
}
/*
1
10 1
abaabbaabb
6 9 6
2 8 3
1 8 5
9 9 9
5 10 7
5 7 7
7 8 7
5 6 6
1 9 9
3 9 5
*/

详细

Test #1:

score: 100
Accepted
time: 0ms
memory: 6888kb

input:

2
10 4
baaabbabba
2 8 3
1 1 1
2 3 2
2 5 4
20 3
cccbccbadaacbbbcccab
14 17 16
3 20 17
17 20 18

output:

2
1
2
3
4
15
3

result:

ok 7 numbers

Test #2:

score: 0
Accepted
time: 13ms
memory: 7400kb

input:

8994
10 10
abaabbaabb
2 8 3
1 8 5
6 9 6
9 9 9
5 10 7
5 7 7
7 8 7
5 6 6
1 9 9
3 9 5
2 1
ab
1 2 1
8 6
bbabaabb
3 7 7
5 7 7
1 5 1
1 4 3
3 5 3
5 5 5
10 3
aababbaaab
3 4 4
6 9 8
4 6 6
7 3
babbaab
5 6 5
3 6 6
1 6 6
9 3
baaaabbba
2 5 2
8 9 8
1 4 4
9 2
babaababa
2 4 4
2 6 3
2 3
ba
1 2 2
1 2 1
2 2 2
10 2
aba...

output:

3
8
4
1
1
1
2
1
6
7
1
4
3
5
1
2
1
1
2
2
2
1
1
4
2
1
1
5
1
2
1
5
2
3
1
1
1
4
3
2
1
1
3
1
2
1
1
1
1
1
1
1
1
1
1
1
1
1
3
1
1
1
1
1
1
1
3
2
1
2
1
1
2
3
1
1
1
2
1
1
1
1
1
1
1
1
2
1
1
2
2
1
2
2
2
2
1
2
2
1
1
5
1
1
3
2
4
1
2
1
2
1
1
1
4
2
2
2
6
1
1
2
2
1
2
1
4
4
1
1
1
1
1
1
1
2
1
4
2
3
2
2
1
4
2
2
2
2
1
2
...

result:

ok 50000 numbers

Test #3:

score: 0
Accepted
time: 20ms
memory: 7292kb

input:

3349
12 39
ccccaabbacac
7 11 10
2 11 2
2 6 4
8 10 9
4 7 4
6 12 8
5 10 10
10 12 10
1 8 8
8 10 8
1 3 3
8 10 8
7 7 7
9 11 10
2 9 6
1 2 1
10 12 10
5 6 5
2 11 2
7 11 7
4 4 4
3 4 3
11 12 11
1 7 4
3 12 6
6 8 7
6 12 11
1 9 6
5 11 5
4 5 4
3 8 8
2 9 3
6 10 8
1 3 3
1 11 11
6 11 6
8 11 11
6 9 6
3 9 4
20 2
accba...

output:

5
10
3
1
4
4
6
3
3
2
1
2
1
3
3
2
3
2
10
4
1
2
1
4
2
3
2
3
2
2
3
7
3
1
1
2
1
2
6
5
9
1
6
3
1
1
2
3
3
2
2
5
4
2
8
1
2
5
1
3
6
3
5
5
1
2
3
1
4
4
2
5
2
3
2
3
2
1
3
1
1
5
7
4
5
6
7
4
1
4
1
7
14
2
3
4
1
4
3
1
1
1
9
2
3
3
7
2
7
8
4
7
4
3
3
3
6
1
3
2
1
2
2
2
5
3
3
3
1
4
8
6
3
1
1
5
1
1
2
1
4
2
10
1
6
1
4
1
...

result:

ok 50000 numbers

Test #4:

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

input:

333
130 121
cdbcacbdbcaccccdbabadddbccbcadbadbcdddcbdcdcaddcaccdbaaadcbdbadabddaddadccdbadbbbaabdadabcbadacaabcabdaddbdaacbccbdddddcaacbcdcdab
81 115 82
22 81 24
49 95 57
22 101 26
66 71 66
90 98 92
31 118 98
70 70 70
33 77 64
61 126 99
11 34 14
9 89 70
17 101 94
5 56 34
47 83 54
2 10 6
63 68 64
47 ...

output:

2
21
44
46
6
4
32
1
4
37
17
59
11
19
3
7
2
35
21
16
2
38
25
23
3
40
1
53
17
72
64
11
4
20
11
25
10
56
13
8
98
37
8
43
16
3
34
9
91
36
10
22
2
15
11
3
4
21
85
17
2
32
1
6
1
26
2
79
1
4
7
2
4
10
16
2
19
3
39
7
32
66
4
2
22
67
2
16
34
25
11
1
30
44
32
6
32
26
25
1
36
39
44
46
5
11
29
14
10
7
3
26
20
30...

result:

ok 50000 numbers

Test #5:

score: 0
Accepted
time: 46ms
memory: 10904kb

input:

32
1618 204
bdbcacdcecbeaabdcebdcedeacbaeadadbaaceebaeccacdadcabaaebeabdabdcbabaececbeccddbdeabcebebdcdcbbcccebdcecbbadbebbcacacecbbbaddebcaecadccdadccdddaaabaeacebbcaddacaabcbdccabedccbebbcebeeadcdecbbdaabecebeaddaadaeeecbcadeaaeeaedbddceabadcbdbcabbbedcabaacaddcbccdcdeebdadbeeeaebbbdeebbaebdbecadc...

output:

17
33
74
113
19
7
83
262
25
118
47
42
106
144
91
225
64
443
21
68
100
21
152
524
511
74
49
3
642
544
23
123
59
547
45
459
37
718
99
22
140
234
847
127
4
115
921
64
173
296
148
192
96
115
3
5
594
377
936
510
7
84
39
268
89
19
78
252
938
297
45
57
429
992
1160
23
3
47
526
609
30
30
1
1116
364
355
64
4...

result:

ok 50000 numbers

Test #6:

score: 0
Accepted
time: 63ms
memory: 13700kb

input:

3
14322 3266
ahdmjrtnnkvotzitfqctsisxdlevjmdpocarqibnvfgpmlwkeuynawqzhnjwvtzxlckeawjwmaobieqaflnnlovlpxnjtafikqhvviqmkcyhiljgsohiqkxrpajshiighwhtglkrnbofakpqlxuwiruddxvntsvhgmwzitrtznsydvmyfhqltgtuoakvyxezwpkfwgurykrsekcaapjrvfmtljtxnvraisnvybuzveqvfglnhhqgrecvwiyzgerkwzeayvdhkfdmiwdgvxpyqajevefzzxn...

output:

3188
47
2495
4509
3896
564
619
1537
266
61
1746
148
804
1857
4589
7088
1449
344
937
4533
70
2727
62
5225
3477
341
93
121
5058
1706
1939
2786
98
342
314
4701
2938
1998
466
194
615
975
3044
432
2108
578
302
4645
3201
419
1233
345
907
4760
4944
1707
357
1297
1253
256
18
4371
3859
1029
308
860
3256
2444...

result:

ok 50000 numbers

Test #7:

score: 0
Accepted
time: 89ms
memory: 15924kb

input:

1
50000 50000
bbbbababaaaabababaaabaabaabbabbabbaaabbbbbbabbbababaaaaabbaaabbbababbbaabaabababababbbabaaaababaababbabbbabbbabaabbbbbaababaaaabaaaaaabaabbaaaabbaaababbbabbaabaababbbaabbbbaabbbbabbaabbabababaaabaababaabaabababbabbbabaaabaaabaabbaabbaabababaaaaabaabbabbbaaaabbbabbabbbaaabaaaabbbbaabbaa...

output:

14106
7199
315
23
21768
4574
19032
9447
1399
4075
4509
3770
22703
9626
11967
39
8208
14885
9810
2885
1501
4344
5191
11468
25450
22059
10473
7168
5765
12478
5895
9215
26023
17780
21556
22347
9214
3076
897
17612
122
79
1237
6864
8620
15374
10972
18213
2633
9313
1003
15871
1814
6148
28475
9887
3248
262...

result:

ok 50000 numbers

Test #8:

score: 0
Accepted
time: 85ms
memory: 15692kb

input:

1
50000 50000
aacccdaaabbbdcdbbccdddabbcbcacacdaaccaabcdaabcbcccbbbcadbdacabdbdddaddbabdcbcbacaddbdababcdadcbccacbdabcdbcaabcacddccbbdcdcbdcabcdbaadccccbccabbabcdbdcdddcadaddcabcbbdabaacabadcccbaaadbbbaaacdddabdaaabbaacbaaaabcadbacbbaadbbdbadaccdabaabcdddbcbaadaaabbbabbabbdcdadacbdacdbcaccadaccbcbcd...

output:

3461
254
1838
11909
11583
31007
498
649
5860
32819
18923
11053
2374
2864
9971
17207
1809
38307
302
6601
8782
31585
1179
2468
8836
231
578
6954
14984
14872
14214
4800
30011
7393
3173
1337
3929
210
29907
28679
5533
25781
5465
2763
10445
16179
5934
7912
10297
1839
42608
57
2590
12060
355
13200
7015
129...

result:

ok 50000 numbers

Test #9:

score: 0
Accepted
time: 83ms
memory: 15684kb

input:

1
50000 50000
ccccdcabcabababbbdadddabccdbddcbacdcbcaadccdabcbaadccbdddccddccbdabaccbcaddbabbbabaadccacbcbaadbacacdadddacdcbbabacbbcabbddccbbdcdbcbcddaabdaaccddbcaccbcbbcbbbbbdddbaadbdddacaddbcbaacaacbccbccbdcccacbabbdcddaacdacdcdaccbaaacdccbaacdadbbaaaacccdbaaaabaddcabcaadaddbbabdadcdccdabbabcdaaad...

output:

51
4
27
10
41
8
17
78
26
6
24
7
4
10
25
74
28
1
15
27
19
28
54
25
1
33
63
4
1
19
6
48
13
20
44
26
7
1
22
50
10
65
5
5
43
34
4
3
16
8
32
40
16
15
80
7
14
45
22
15
13
7
65
45
64
12
14
16
22
2
10
26
66
30
17
35
19
4
55
17
78
8
14
85
27
2
37
1
2
4
11
3
7
22
55
29
7
33
4
5
15
18
15
8
9
21
73
40
8
51
97
2...

result:

ok 50000 numbers

Test #10:

score: 0
Accepted
time: 72ms
memory: 15552kb

input:

1
50000 50000
aadddbddbdcdccdbabcdddaaadadbbaabdcbbbdddbdcdadabdcdadbcccdabdbcabddabbdaadbcccadcbdddabcaacabbdcadccbcaadcbdaddabbaadcdadadaadbcdbbdcaabccbddcddaabdabcbdbbdcadadbabdbbbbbbbcadaaccbbacacbaaccbacddcaaddbcbbbdaadbdadabbcdcabdddcacbbcadbbcabbacddbcacbacdbbbccacdccdccbbcdbacbcadddcdbcccaba...

output:

36865
42672
42156
10085
25214
47946
30569
21888
33007
35476
36946
21089
36483
12561
33367
41731
27460
48902
28849
20015
19159
28062
14416
18329
11212
12037
10917
3712
35131
46782
11706
8985
19189
12099
33959
33208
31030
45412
33806
35752
13400
40607
7991
63
26773
11302
49091
45123
25752
41971
22347
...

result:

ok 50000 numbers

Test #11:

score: 0
Accepted
time: 665ms
memory: 15692kb

input:

1
50000 50000
abbabaabbaababbabaababbaabbabaabbaababbaabbabaababbabaabbaababbabaababbaabbabaababbabaabbaababbaabbabaabbaababbabaababbaabbabaabbaababbaabbabaababbabaabbaababbaabbabaabbaababbabaababbaabbabaababbabaabbaababbabaababbaabbabaabbaababbaabbabaababbabaabbaababbabaababbaabbabaababbabaabbaabab...

output:

5855
2148
26567
2625
128
5098
1225
664
1545
191
4136
7212
5468
553
1812
26073
6982
10498
6603
39035
11224
5846
2458
7319
12828
183
4300
8432
33925
4990
2326
9727
4668
13597
5830
596
280
6170
847
71
1872
11735
37093
5197
78
1316
10896
20194
1503
14076
2631
1465
15898
7885
2119
373
13524
430
693
4075
...

result:

ok 50000 numbers

Test #12:

score: 0
Accepted
time: 395ms
memory: 15656kb

input:

1
50000 50000
abcdbcdacdabdabcbcdacdabdabcabcdcdabdabcabcdbcdadabcabcdbcdacdabbcdacdabdabcabcdcdabdabcabcdbcdadabcabcdbcdacdababcdbcdacdabdabccdabdabcabcdbcdadabcabcdbcdacdababcdbcdacdabdabcbcdacdabdabcabcddabcabcdbcdacdababcdbcdacdabdabcbcdacdabdabcabcdcdabdabcabcdbcdabcdacdabdabcabcdcdabdabcabcdbc...

output:

13759
14609
31791
39936
36123
30296
19881
7134
20834
32564
45651
47333
4564
24019
16289
46779
47360
3234
7411
2726
19219
4356
39363
28275
5049
31201
10923
22540
16779
1616
31053
14379
13020
37468
45757
33749
45756
28789
3344
11437
43105
15989
1971
30546
10673
15980
5672
39006
34031
22966
42602
26758...

result:

ok 50000 numbers

Test #13:

score: 0
Accepted
time: 1458ms
memory: 16208kb

input:

1
50000 50000
vrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrvvrvrvvrvrvvrvvrvrvvrv...

output:

31613
16411
28710
2555
12382
21580
5813
10802
7585
34504
3218
17485
41408
22359
41670
38427
40722
44095
16092
38904
4228
13246
751
17256
16669
43246
4299
18678
43936
4195
32284
12474
33646
19570
29219
42978
20541
20304
39745
6735
1495
21036
4862
21608
11324
46619
45135
34357
25479
43668
18106
17432
...

result:

ok 50000 numbers

Test #14:

score: 0
Accepted
time: 72ms
memory: 16028kb

input:

1
50000 50000
fnnfffffnfffffnffufnffnffffuffffffunfffnfnfnfffffnfnfffnffffnfkffunffffffafufffffffuufnffffffffnffffffffffffffnfffuunfffnfffffffnfnffnffffffffffffffnnnnfffnfffffffnffffnffuffffffffffffffffffnnfnfffffnfnffffnffuffffffuffffnnfnfunffffnfnffnfffffffffffnffffnunffffnfnffnfnffffufffffffffuff...

output:

33022
5053
37365
39912
46985
94
20342
10009
49594
35986
28105
38799
41672
9389
24061
23165
13107
30144
48878
21638
11236
18926
8861
36347
16948
16458
7674
46789
20206
11757
40171
3933
11699
48411
16354
2169
11058
20649
34526
39373
49275
31851
21522
36281
19732
20806
39137
34617
48442
8636
40454
2408...

result:

ok 50000 numbers

Test #15:

score: 0
Accepted
time: 78ms
memory: 15516kb

input:

1
50000 50000
vvvvhvhvvvvvvvvvvvhvvvvvvvvvvvvhvvvvhvvvvvvvvvvvvvvhvvvvvvvvvvvvvvhvvvvvvvvhvvvvvvvvvvvvvvvvvvvvvvvvhvvvvvvvvvvvvvvhvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvhvhvvvvvvvvvvvvvvvvvvvvvvvvhvvvvhvvvwvvvhvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvhvvvhvvvvvvvvvvvvvvvvvwvhvvvvvvvhhvvvvvvvvhvvvvhvvvvvvvvvvvv...

output:

34659
4905
40501
25217
14282
3312
40611
6521
27071
33978
44954
31849
22748
16148
19857
31458
14507
17735
29795
43992
26810
6201
7699
8091
47211
46296
42080
22699
14821
20522
19191
9177
15764
8747
1067
5646
25528
20362
7324
38174
4671
39716
11209
16991
19436
38875
49516
36685
29167
15039
34835
32992
...

result:

ok 50000 numbers

Test #16:

score: -100
Time Limit Exceeded

input:

1
50000 50000
dmdedmdxdmdedmdtdmdedmdxdmdedmdldmdedmdxdmdedmdtdmdedmdxdmdedmdqdmdedmdxdmdedmdtdmdedmdxdmdedmdldmdedmdxdmdedmdtdmdedmdxdmdedmdpdmdedmdxdmdedmdtdmdedmdxdmdedmdldmdedmdxdmdedmdtdmdedmdxdmdedmdqdmdedmdxdmdedmdtdmdedmdxdmdedmdldmdedmdxdmdedmdtdmdedmdxdmdedmdbdmdedmdxdmdedmdtdmdedmdxdmdedm...

output:


result: