QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#422458#7901. Basic Substring Structureushg8877WA 19ms20332kbC++141.8kb2024-05-27 14:46:112024-05-27 14:46:12

Judging History

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

  • [2024-05-27 14:46:12]
  • 评测
  • 测评结果:WA
  • 用时:19ms
  • 内存:20332kb
  • [2024-05-27 14:46:11]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define MP make_pair
mt19937 rnd(time(0));
const int MAXN=2e5+5;
const int MOD=1e9+7;
int n,a[MAXN];
ll hs[MAXN],pw[MAXN],tot,P=rnd()%MOD;
ll get_hs(ll l,ll r){return (hs[r]-pw[r-l+1]*hs[l-1]%MOD+MOD)%MOD;}
ll change(int l,int r,int x,int c){
	if(x<l||x>r) return 0;
	return (c-a[x]+MOD)*pw[r-x]%MOD;
}
unordered_map<int,ll> mp[MAXN];
ll s0[MAXN],s1[MAXN];
void solve(){
	cin>>n;
	tot=n;
	for(int i=1;i<=n;i++){
		mp[i].clear();
		s0[i]=s1[i]=0;
	}
	for(int i=1;i<=n;i++) cin>>a[i],hs[i]=(hs[i-1]*P+a[i])%MOD;
	for(int i=2;i<=n;i++){
		int l=i-1,r=n,mid;
		while(l<r){
			mid=l+r+1>>1;
			if(get_hs(i,mid)==get_hs(1,mid-i+1)) l=mid;
			else r=mid-1;
		}
		tot+=l-i+1;
		// [i,l] += (l+1-x)
		s0[i]+=l+1;s0[l+1]-=l+1;
		s1[i]--;s1[l+1]++;
		// [1,l+1-i] += (l+2-i-j)
		if(l+1-i<i){
			s0[1]+=l+2-i;s0[l+2-i]-=l+2-i;
			s1[1]--;s1[l+2-i]++;
		}else{
			s0[1]+=l+2-i;s0[i]-=l+2-i;
			s1[1]--;s1[i]++;
		}
		if(l!=n){
			int j=l+1,p=j-i+1;
			l=j,r=n;
			while(l<r){
				mid=l+r+1>>1;
				if(get_hs(j+1,mid)==(get_hs(p+1,mid-j+p)+change(p+1,mid-j+p,j,a[p]))%MOD) l=mid;
				else r=mid-1;
			}
			mp[j][a[p]]+=l-j+1;
			l=j,r=n;
			while(l<r){
				mid=l+r+1>>1;
				if(get_hs(j+1,mid)==get_hs(p+1,mid-j+p)) l=mid;
				else r=mid-1;
			}
			mp[p][a[j]]+=l-j+1;
		}
	}
	ll res=0;
	for(int i=1;i<=n;i++){
		s0[i]+=s0[i-1];s1[i]+=s1[i-1];
		ll ans=0;
		for(auto j:mp[i]) ans=max(ans,j.second);
		res+=(tot-(s0[i]+i*s1[i])+ans)^i;
	}
	cout<<res<<'\n';
	return;

}
int main(){
	ios::sync_with_stdio(false);
	// freopen("Otomachi_Una.in","r",stdin);
	// freopen("Otomachi_Una.out","w",stdout);
	pw[0]=1;
	for(int i=1;i<MAXN;i++) pw[i]=pw[i-1]*P%MOD;
	int _;cin>>_;
	while(_--) solve();
	return 0;
}

详细

Test #1:

score: 100
Accepted
time: 3ms
memory: 20332kb

input:

2
4
2 1 1 2
12
1 1 4 5 1 4 1 9 1 9 8 10

output:

15
217

result:

ok 2 lines

Test #2:

score: -100
Wrong Answer
time: 19ms
memory: 16916kb

input:

10000
8
2 1 2 1 1 1 2 2
9
2 2 1 2 1 2 1 2 1
15
2 1 2 1 1 1 1 2 2 1 2 1 2 2 1
2
1 1
10
2 1 1 1 2 2 1 1 2 2
3
2 1 2
11
1 2 2 1 1 2 1 2 2 1 1
14
2 1 1 1 1 2 1 1 1 2 2 1 2 1
12
2 2 2 1 2 2 2 1 1 2 1 2
4
2 1 1 2
8
1 2 2 2 1 2 1 1
8
1 1 2 1 2 1 1 1
6
2 1 1 1 2 2
14
2 2 1 1 1 1 2 2 2 1 2 2 1 1
10
1 2 2 1 1...

output:

100
133
352
3
211
9
265
363
287
15
95
111
58
352
225
3
344
362
374
316
3
17
129
72
15
92
36
257
16
63
28
94
90
104
249
196
21
47
317
63
102
20
24
65
314
362
264
307
360
281
328
295
232
312
3
330
57
328
3
69
35
146
323
45
351
91
245
3
162
356
246
20
154
3
419
393
387
81
268
369
20
57
21
279
3
17
351
...

result:

wrong answer 1st lines differ - expected: '94', found: '100'