QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#473289#8527. Power DivisionsGenshinImpactsFaultWA 2503ms94736kbC++142.7kb2024-07-12 00:33:562024-07-12 00:33:56

Judging History

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

  • [2024-07-12 00:33:56]
  • 评测
  • 测评结果:WA
  • 用时:2503ms
  • 内存:94736kb
  • [2024-07-12 00:33:56]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
const int N = 1000010;
const int mod = 1e9 + 7;
const int mod1 = 1e9 + 7, mod2 = 1e9 + 9;
int n, a[N];
int ba1[N], ba2[N];
int sum1[N], sum2[N];
map<pair<int, int>, int> ma;
int f[N];
vector<int> t[N];
int stal[N], topl;
int star[N], topr;

void solve(int l, int r) {
	if(l >= r) {
		t[r].push_back(l - 1);
		return ;
	}
	int mid = (l + r) >> 1;
	solve(l, mid), solve(mid + 1, r);
	topl = topr = 0;
	for(int i = l; i <= mid; i++) {
		for(; topl > 0 && a[stal[topl]] >= a[i]; --topl);
		stal[++topl] = i;
	}
	for(int i = r; i > mid; i--) {
		for(; topr > 0 && a[star[topr]] >= a[i]; --topr);
		star[++topr] = i;
	}
	stal[0] = l - 1, star[0] = r + 1;
	map<pair<int, int>, int> mal, mar;
	for(int i = l - 1; i < mid; i++) mal[{sum1[i], sum2[i]}] = i;
	for(int i = mid + 1; i <= r; i++) mar[{sum1[i], sum2[i]}] = i;
	for(int i = topl, j = topr; i || j;) {
		int u = stal[i], v = star[j];
		if(!j || (i && a[u] < a[v])) {
			// stal[i - 1] + 1 -> u, mid + 1 -> v - 1
			// cout << ">>> l : " << stal[i - 1] + 1 << " " << u << " -> " << mid + 1 << " " << v - 1 << "\n";
			for(int k = stal[i - 1] + 1; k <= u; k++) {
				for(int h = a[u] + 1; h <= a[u] + 19; h++) {
					int s1 = (sum1[k - 1] + ba1[h]) % mod1;
					int s2 = (sum2[k - 1] + ba2[h]) % mod2;
					if(mar.find({s1, s2}) != mar.end()) {
						int x = mar[{s1, s2}];
						if(x <= v - 1) t[x].push_back(k - 1);
					}
				}
			}
			--i;
		}
		else {
			// u + 1 -> mid, v -> star[j - 1] - 1
			// cout << ">>> r : " << u + 1 << " " << mid << " -> " << v << " " << star[j - 1] - 1 << "\n";
			for(int k = v; k <= star[j - 1] - 1; k++) {
				for(int h = a[v] + 1; h <= a[v] + 19; h++) {
					int s1 = (sum1[k] - ba1[h] + mod1) % mod1;
					int s2 = (sum2[k] - ba2[h] + mod2) % mod2;
					if(mal.find({s1, s2}) != mal.end()) {
						int x = mal[{s1, s2}];
						if(x >= u) t[k].push_back(x);
					}
				}
			}
			--j;
		}
	}
}
int main() {
	ios::sync_with_stdio(0); cin.tie(nullptr);
	cin >> n;
	for(int i = 1; i <= n; i++) cin >> a[i];
	ba1[0] = ba1[0] = 1;
	for(int i = 1; i <= 1000000; i++) {
		ba1[i] = 1ll * ba1[i - 1] * 2 % mod1;
		ba2[i] = 1ll * ba2[i - 1] * 2 % mod2;
	}
	ma[{0, 0}] = 0;
	for(int i = 1; i <= n; i++) {
		sum1[i] = (sum1[i - 1] + ba1[a[i]]) % mod1;
		sum2[i] = (sum2[i - 1] + ba2[a[i]]) % mod2;
		ma[{sum1[i], sum2[i]}] = i;
	}
	solve(1, n);
	f[0] = 1;
	for(int i = 1; i <= n; i++) {
		sort(t[i].begin(), t[i].end());
		t[i].resize(unique(t[i].begin(), t[i].end()) - t[i].begin());
		// for(auto v : t[i]) cout << v + 1 << " " << i << "\n";
		for(auto v : t[i]) f[i] = (f[i] + f[v]) % mod;
	}
	cout << f[n] << "\n";
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 4ms
memory: 41860kb

input:

5
2 0 0 1 1

output:

6

result:

ok 1 number(s): "6"

Test #2:

score: 0
Accepted
time: 3ms
memory: 39532kb

input:

1
0

output:

1

result:

ok 1 number(s): "1"

Test #3:

score: 0
Accepted
time: 8ms
memory: 41468kb

input:

2
1 1

output:

2

result:

ok 1 number(s): "2"

Test #4:

score: 0
Accepted
time: 7ms
memory: 40048kb

input:

3
2 1 1

output:

3

result:

ok 1 number(s): "3"

Test #5:

score: 0
Accepted
time: 10ms
memory: 42808kb

input:

4
3 2 2 3

output:

4

result:

ok 1 number(s): "4"

Test #6:

score: 0
Accepted
time: 7ms
memory: 41444kb

input:

5
3 4 4 2 4

output:

2

result:

ok 1 number(s): "2"

Test #7:

score: 0
Accepted
time: 7ms
memory: 42848kb

input:

7
3 4 3 5 6 3 4

output:

6

result:

ok 1 number(s): "6"

Test #8:

score: 0
Accepted
time: 10ms
memory: 42096kb

input:

10
8 6 5 6 7 8 6 8 9 9

output:

4

result:

ok 1 number(s): "4"

Test #9:

score: 0
Accepted
time: 7ms
memory: 42672kb

input:

96
5 1 0 2 5 5 2 4 2 4 4 2 3 4 0 2 1 4 3 1 2 0 2 2 3 2 4 5 3 5 2 0 2 2 5 3 0 4 5 3 5 4 4 3 1 2 0 5 4 5 0 2 3 2 4 0 0 4 2 0 2 5 3 3 1 5 5 1 1 1 0 5 0 3 0 2 1 1 0 5 0 3 3 4 4 5 3 0 2 2 0 5 4 5 0 5

output:

11332014

result:

ok 1 number(s): "11332014"

Test #10:

score: 0
Accepted
time: 8ms
memory: 42992kb

input:

480
2 0 4 4 1 0 0 3 1 1 4 2 5 5 4 2 1 2 4 4 1 3 4 3 0 5 2 0 2 5 1 0 5 0 0 5 5 0 2 5 2 2 3 1 4 3 5 4 5 2 4 4 4 4 1 4 0 3 4 3 4 1 0 4 3 4 5 4 3 5 0 2 2 0 1 5 4 4 2 0 3 3 3 4 3 0 5 5 3 1 5 1 0 1 0 4 3 0 5 1 4 1 4 3 0 1 3 5 0 3 3 1 0 4 1 1 2 0 1 2 0 3 5 2 0 5 5 5 5 3 5 1 0 2 5 2 2 0 2 0 2 3 5 1 2 1 5 4 ...

output:

506782981

result:

ok 1 number(s): "506782981"

Test #11:

score: 0
Accepted
time: 9ms
memory: 42788kb

input:

2400
0 2 2 0 5 4 3 2 3 2 5 4 5 4 4 5 2 2 4 2 2 0 1 0 5 0 4 4 0 0 5 0 4 0 1 3 4 5 0 3 1 0 4 0 2 5 0 3 3 3 3 1 0 5 5 3 1 3 5 2 4 0 5 0 4 5 4 2 2 1 5 2 2 4 1 0 5 1 5 0 1 2 0 0 3 5 4 0 0 1 1 1 4 2 0 5 1 3 3 5 0 4 4 1 5 5 3 4 4 4 0 2 4 0 5 1 3 1 5 0 5 5 1 3 0 3 1 2 0 1 1 3 5 2 3 4 0 3 0 5 4 0 4 3 5 0 5 2...

output:

586570528

result:

ok 1 number(s): "586570528"

Test #12:

score: 0
Accepted
time: 56ms
memory: 43496kb

input:

12000
2 2 1 2 0 2 5 3 2 0 1 3 2 5 4 0 0 5 3 2 0 2 3 4 3 2 1 4 3 0 3 5 4 1 0 2 4 1 3 2 3 5 0 3 0 0 4 0 4 5 1 0 4 1 1 1 5 4 3 0 3 5 4 5 2 5 0 1 2 3 5 5 2 5 4 2 0 4 4 3 0 0 2 5 0 3 4 2 5 4 2 1 4 5 1 1 2 3 0 3 3 3 3 4 0 5 3 4 0 3 0 2 0 0 2 0 3 4 2 2 0 1 0 5 3 0 2 0 2 2 1 0 5 3 5 4 5 5 0 4 0 4 1 4 4 3 2 ...

output:

201653965

result:

ok 1 number(s): "201653965"

Test #13:

score: 0
Accepted
time: 359ms
memory: 51264kb

input:

60000
2 5 0 3 2 3 5 3 5 5 4 1 1 5 3 0 1 1 2 5 5 5 0 3 2 0 3 2 3 3 0 0 1 4 3 1 4 2 3 3 0 5 1 0 1 1 5 5 4 0 5 4 1 3 1 3 5 3 2 4 4 4 5 4 3 2 3 2 4 5 2 0 4 5 1 2 0 4 0 5 1 3 4 1 2 4 1 1 3 3 0 1 1 3 0 0 2 3 3 2 1 4 1 2 4 3 3 5 2 5 3 4 3 0 2 1 1 1 5 1 2 4 2 3 1 2 1 0 2 0 1 1 5 5 3 4 2 5 2 4 5 3 0 5 1 4 2 ...

output:

592751350

result:

ok 1 number(s): "592751350"

Test #14:

score: -100
Wrong Answer
time: 2503ms
memory: 94736kb

input:

300000
0 5 1 5 5 4 5 3 0 5 0 5 1 4 1 2 2 2 3 0 1 5 4 0 3 1 4 5 2 1 0 3 2 1 2 5 0 2 4 5 0 1 2 1 1 0 0 5 3 0 0 3 4 5 0 2 1 1 1 2 5 1 4 3 1 0 2 0 0 4 3 3 2 5 3 3 1 5 2 0 2 4 3 1 0 3 4 1 3 3 1 0 0 1 1 1 3 1 2 3 5 3 3 2 0 3 0 0 5 5 0 0 0 0 1 4 3 3 4 3 4 5 3 3 5 1 1 4 2 2 1 3 2 1 1 0 0 5 5 0 0 3 2 4 5 5 2...

output:

222252080

result:

wrong answer 1st numbers differ - expected: '842503795', found: '222252080'