QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#759460#9631. Median ReplacementAndycraftTL 9ms4036kbC++232.4kb2024-11-18 08:56:322024-11-18 08:56:32

Judging History

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

  • [2024-11-18 08:56:32]
  • 评测
  • 测评结果:TL
  • 用时:9ms
  • 内存:4036kb
  • [2024-11-18 08:56:32]
  • 提交

answer

#include <iostream>
#include <vector>
#include <algorithm>
template <class T> using Arr = std::vector<T>;
typedef long long LL;
const int MOD = 1e9 + 7;
#define MUL(u, v) (int)((LL)(u) * (v) % MOD)
inline int Pow(int a, int b) { int r = 1; for (; b > 0; b >>= 1, a = MUL(a, a)) if (b & 1) r = MUL(r, a); return r; }
const int MAXN = 155;
int n;
int L[MAXN], R[MAXN];
int f[MAXN][3];
int all;

inline int lt(int x, int l, int r) { return std::min(r - l + 1, std::max(0, x - l)); }
inline int gt(int x, int l, int r) { return std::min(r - l + 1, std::max(0, r - x + 1)); }

void DP(int x) {
	f[0][2] = 1;
	for (int i = 1; i <= n; ++i) {
		f[i][0] = MUL(f[i - 1][2], gt(x, L[i], R[i]));
		f[i][1] = MUL(f[i - 1][0], lt(x, L[i], R[i]));
		f[i][2] = MUL(f[i - 1][1] + f[i - 1][2], lt(x, L[i], R[i]));
	}
}

int Summary(Arr<int> pts, int K) {
	int ans = 0;
	for (int i = 0; i < (int)pts.size(); ++i) {
		int prod = 1;
		for (int j = 0; j < (int)pts.size(); ++j)
			if (i != j)
				prod = MUL(prod, MUL(K - j, Pow(i - j, MOD - 2)));
		ans = (ans + MUL(prod, pts[i])) % MOD;
	}
	return ans;
}

int Calc(int l, int r) {
	// printf("Calc %d %d\n", l, r);
	Arr<int> pts;
	for (int i = l; i <= std::min(r, l + n + 5); ++i) {
		DP(i);
		// printf("= %d %d %d\n", f[n][0], f[n][1], f[n][2]);
		pts.push_back(((LL)f[n][0] + f[n][1] + f[n][2]) % MOD);
	}
#if 0
	printf("# ");
	for (int i = 0; i < (int)pts.size(); ++i)
		printf("%d ", pts[i]);
	puts("");
#endif
	for (int i = 0; i + 1 < (int)pts.size(); ++i)
		pts[i] = MUL(l + i, pts[i + 1] - pts[i]);
	for (int i = 1; i < (int)pts.size(); ++i)
		pts[i] = (pts[i - 1] + pts[i]) % MOD;
	pts.erase(std::prev(pts.end()));
	return Summary(pts, r - l - 1);
}

void Solve() {
	std::cin >> n;
	Arr<int> ps;
	for (int i = 1; i <= n; ++i)
		std::cin >> L[i], ps.push_back(L[i]), ps.push_back(L[i] - 1);
	for (int i = 1; i <= n; ++i)
		std::cin >> R[i], ps.push_back(R[i]), ps.push_back(R[i] + 1);
	all = 1;
	for (int i = 1; i <= n; ++i)
		all = MUL(all, R[i] - L[i] + 1);
	std::sort(ps.begin(), ps.end());
	ps.erase(std::unique(ps.begin(), ps.end()), ps.end());
	int ans = 0;
	for (int i = 1; i < (int)ps.size(); ++i)
		ans = (ans + Calc(ps[i - 1], ps[i])) % MOD;
	printf("%d\n", ans < 0 ? ans + MOD : ans);
}

int main() {
	std::ios::sync_with_stdio(false);
	int T;
	std::cin >> T;
	while (T--)
		Solve();
	return 0;
}

/*
2
3
1 1 1
1 1 1
3
1 1 1
1 2 2
*/

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 1ms
memory: 3772kb

input:

10
5
5 1 4 3 2
14 2 5 3 2
5
4 5 1 2 3
13 7 1 2 3
5
5 2 5 3 1
10 2 12 3 2
5
5 5 3 1 5
57 5 3 1 5
5
2 2 3 3 5
4 5 4 4 5
5
4 5 3 5 3
13 7 3 5 3
5
5 1 4 2 3
14 3 4 2 3
5
1 2 5 4 5
2 8 5 7 5
5
1 1 3 5 1
8 2 3 8 1
5
4 4 4 2 3
5 10 5 2 3

output:

180
170
650
265
182
173
120
296
192
131

result:

ok 10 lines

Test #2:

score: 0
Accepted
time: 0ms
memory: 3772kb

input:

10
5
1 2 2 5 3
6 4 2 6 3
5
4 4 1 4 3
6 7 2 5 3
5
5 3 4 2 4
5 7 5 2 6
5
1 5 3 5 2
7 7 3 5 2
5
1 3 3 2 2
10 5 3 2 2
5
4 4 4 5 3
4 11 9 5 3
5
5 3 2 1 3
13 5 2 1 5
5
5 4 1 2 5
10 6 1 2 5
5
3 5 3 4 2
5 9 3 5 2
5
1 1 3 2 1
7 3 3 3 1

output:

120
230
144
110
110
289
324
89
140
122

result:

ok 10 lines

Test #3:

score: 0
Accepted
time: 0ms
memory: 3748kb

input:

10
5
3 1 3 4 4
9 1 3 10 4
5
1 1 3 1 1
9 1 3 3 1
5
5 1 2 3 1
74 1 2 3 1
5
2 5 5 3 4
5 6 8 3 4
5
2 1 3 4 5
2 4 6 4 5
5
2 4 2 1 3
2 11 3 2 3
5
1 5 4 4 2
1 14 6 6 2
5
4 1 3 5 1
9 2 4 5 1
5
4 1 2 4 4
6 1 6 4 4
5
3 2 5 3 5
8 8 5 3 5

output:

196
76
140
172
72
80
486
84
65
224

result:

ok 10 lines

Test #4:

score: 0
Accepted
time: 1ms
memory: 3792kb

input:

10
5
676437428 903889545 700650370 965758082 146716866
676437431 903889567 700650370 965758082 146716866
5
517457740 64600397 388618400 783268973 388618400
517457797 64600397 388618400 783268973 388618400
5
971452763 106948541 259878781 537741075 9504353
971452780 106948544 259878781 537741075 95043...

output:

157838571
539867046
711272106
123881231
497944943
9791579
539012259
963879245
315607794
495624077

result:

ok 10 lines

Test #5:

score: 0
Accepted
time: 1ms
memory: 3764kb

input:

10
5
462008700 417744555 925098328 70231697 547596413
462008735 417744555 925098328 70231697 547596413
5
294230630 403894618 294230635 403894620 403894617
294230638 403894620 294230635 403894620 403894617
5
757647830 757647826 757647828 184694646 161891480
757647839 757647827 757647830 184694646 161...

output:

713470735
905154643
458869425
477055327
633375786
349097981
980046476
478461437
573246310
810688575

result:

ok 10 lines

Test #6:

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

input:

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

output:

8640
8000
9600
8100
9360
9900
9600
9960
9300
5560

result:

ok 10 lines

Test #7:

score: 0
Accepted
time: 4ms
memory: 4036kb

input:

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

output:

5760
9600
6580
7680
5280
7200
8640
8000
5400
5040

result:

ok 10 lines

Test #8:

score: 0
Accepted
time: 4ms
memory: 3836kb

input:

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

output:

8800
8100
5040
5580
9600
7200
6400
5184
7560
8640

result:

ok 10 lines

Test #9:

score: -100
Time Limit Exceeded

input:

10
150
390717977 225426217 217154512 811659013 811659022 811659006 811659019 811658998 380139276 562680969 391897894 391897902 610662417 702576570 778349151 778349150 144611847 144611847 888681165 952726258 635003873 635003864 365476184 353032583 492888825 492888833 451690481 492888832 492888828 781...

output:


result: