QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#483175#7368. 抄写yb13558h0 0ms0kbC++14925b2024-07-18 12:39:532024-07-18 12:39:53

Judging History

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

  • [2024-07-18 12:39:53]
  • 评测
  • 测评结果:0
  • 用时:0ms
  • 内存:0kb
  • [2024-07-18 12:39:53]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
char s[1100000];
int n,q,p[1100000];
int mst[21][1100000];
void init(){
	for(int i=1;i<=n;i++)mst[0][i]=p[i];
	for(int j=1;j<=20;j++)
		for(int i=1;i+(1<<j)-1<=n;i++)
			mst[j][i]=max(mst[j-1][i],mst[j-1][i+(1<<j-1)]);
}
int get(int l,int r){
	if(l>r)return -0x3f3f3f3f;
	int k=__lg(r-l+1);
	return max(mst[k][l],mst[k][r-(1<<k)+1]);
}
int main(){
	scanf("%s",s+1),n=strlen(s+1)*2+1,s[0]='&',s[n+1]='%';
	for(int i=n;i>=1;i--)s[i]=i%2?'$':s[i/2];
	for(int i=1,r,mid;i<=n;i++){
		if(i<=r)p[i]=min(r-i+1,p[r*2-i]);
		else p[i]=1;
		while(s[i+p[i]]==s[i-p[i]])p[i]++;
		if(i+p[i]-1>r)r=i+p[i]-1,mid=i;
	}
	init();
	scanf("%d",&q);
	for(int i=1,l,r;i<=q;i++){
		scanf("%d%d",&l,&r);
		int L=2,R=r-l+1,ans=1;l*=2,r*=2;
		while(L<=R){
			int mid=L+R>>1;
			if(get(l+mid-1,r-mid+1)>mid)ans=mid,L=mid+1;
			else R=mid-1;
		}
		printf("%d\n",ans);
	}
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 0
Runtime Error

input:

10 920
316 915 331 834 181 122 238 511 910 632 652 717 369 468 866 140 89 183 83 376 257 670 127 643 983 105
xaaxrdtjqv

output:


result:


Test #2:

score: 0
Runtime Error

input:

659 423
752 190 254 128 821 695 798 216 809 606 970 45 830 149 247 662 348 883 122 310 519 81 420 407 854 141
tttttttttttttttttttttttttttccccccccccqqqqqqqqqqdddddddddddbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbsssssssssssssssssssssssssssssssssssssssssssssssssssssssssssoooooooooooooooooooooo...

output:


result:


Test #3:

score: 0
Runtime Error

input:

1000 82508
77548 11366 41959 92623 12754 24025 69335 82809 10717 2487 20842 21597 79490 55616 4586 81371 61068 60639 38689 99285 67058 4417 48118 92298 48938 46998
fswgxhmntgjmxddxuxddxmjgtnmhxgwuwgxhmntgjmxddxuxddxmjgtnmhxgwuwgxhmntgjmxddxuxddxmjgtnmhxgwuwgxhmntgjmxddxuxddxmjgtnmhxgwuwgxhmntgjmxddx...

output:


result:


Test #4:

score: 0
Runtime Error

input:

1000 81447
73552 15604 67150 50813 61186 62462 95570 13768 1915 12710 9768 10234 73803 67198 83028 62207 7498 72453 18426 76800 20581 66504 49434 7136 9199 40151
jdxxltlxxdjtjdxxltuhsbscjqqgdoyodgqqjcsbshuyuhsbscjqqgdoyodgqqjcsbshuyuhsbscjqqgdoyodgqqjcsbshuyuhsbscjqqgdoyodgqqjcsbshuyuhsbscjqqgdoyodg...

output:


result:


Test #5:

score: 0
Runtime Error

input:

97366 425
238 96 326 413 643 743 806 601 213 8 229 585 852 183 887 272 137 891 480 337 135 411 265 906 807 382
sssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssss...

output:


result:


Test #6:

score: 0
Runtime Error

input:

100000 33379
12170 1675 69834 14368 91570 82932 66141 88159 4220 35820 24836 1083 77102 4471 78735 61628 53746 58134 40036 49369 65424 60061 79771 76791 91398 8101
imqqzaazqqmiimqqzaazqqmiimqqzakuochddhcoukkuochddhcoukkuochddhcoukkuochddhcoukkuochddhcoukkuochddhcoukkuochddhcoukkuochddhcoukkuochddhco...

output:


result:


Test #7:

score: 0
Runtime Error

input:

100000 9107925
3181820 1305477 3152716 3739224 5572782 7916058 6479616 5154334 6622906 5541248 2719333 384761 3475969 4897963 6983868 175635 6509182 3008693 8373041 5777658 7480682 1658648 2725231 3311916 6180881 2740645
mjsgonduqaaqudnogsjmxiddixxiddixxiddixxiddixxiddixxiddixxiddixxiddixxiddixxiddi...

output:


result:


Test #8:

score: 0
Runtime Error

input:

940823 71
102 70 3 282 34 642 912 683 628 633 870 57 395 952 427 275 323 655 720 960 557 114 417 354 557 554
yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy...

output:


result:


Test #9:

score: 0
Runtime Error

input:

1000000 80005
23657 44948 43486 12462 38795 28137 60947 38872 76125 27490 97511 91032 95028 17525 64016 68451 91721 63645 18338 55030 89004 15169 95322 26813 19323 44805
tccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttccttc...

output:


result:


Test #10:

score: 0
Runtime Error

input:

1000000 743705502
203355312 642593104 49509407 833553504 721765697 645923593 987676530 855140950 875859311 522957598 441082466 49068898 921312225 548185354 505533262 26737495 674175585 995483029 131477261 936989048 613365908 712282356 798743656 807929778 320579711 517544929
vhhvvhhvvhhvvhhvvhhvvhhvv...

output:


result: