QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#759460 | #9631. Median Replacement | Andycraft | TL | 9ms | 4036kb | C++23 | 2.4kb | 2024-11-18 08:56:32 | 2024-11-18 08:56:32 |
Judging History
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...