QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#300847 | #4270. Double Attendance | Zhou_JK | 0 | 1ms | 3816kb | C++23 | 1.6kb | 2024-01-08 21:52:15 | 2024-01-08 21:52:16 |
answer
#include <bits/stdc++.h>
using namespace std;
void ckmin(int &x, int y) {
if (x > y) {
x = y;
}
}
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n[2], k;
cin >> n[0] >> n[1] >> k;
vector<pair<int, int>> s[2];
s[0] = s[1] = {{-1, -1}};
for (int t = 0; t < 2; ++t) {
for (int i = 0; i < n[t]; ++i) {
int l, r;
cin >> l >> r;
s[t].push_back({l, r - 1});
}
sort(s[t].begin(), s[t].end());
}
auto find = [&](int t, int x) {
return lower_bound(s[t].begin(), s[t].end(), pair{x + 1, 0});
};
auto in = [&](int t, int x) {
return prev(find(t, x))->second >= x;
};
vector dp(2, vector<int>(n[0] + n[1] + 1, 2e9));
dp[0][in(0, 0)] = 0;
int ans = 0;
for (int i = 0; i < n[0] + n[1]; ++i) {
for (int t = 0; t < 2; ++t) {
if (dp[t][i] > 1e9) {
continue;
}
int x = dp[t][i];
auto p = find(t, x);
if (p != s[t].end()) {
ckmin(dp[t][i + 1], p->first);
}
p = prev(p);
int r = max<int>(x + k, p->second - k + 1);
int add = find(t ^ 1, r) - find(t ^ 1, x + k) + in(t ^ 1, x + k);
ckmin(dp[t ^ 1][i + add], r);
}
}
for (int x = 0; x <= n[0] + n[1]; ++x) {
if (dp[0][x] < 2e9 || dp[1][x] < 2e9) {
ans = x;
}
}
cout << ans << '\n';
return 0;
}
详细
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 5
Accepted
time: 0ms
memory: 3596kb
input:
3 1 8 10 20 100 101 20 21 15 25
output:
3
result:
ok single line: '3'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3552kb
input:
1 5 3 1 100 1 2 2 3 3 4 4 5 5 6
output:
4
result:
ok single line: '4'
Test #3:
score: 0
Accepted
time: 0ms
memory: 3500kb
input:
10 10 5 4 9 43 48 69 70 70 72 52 67 75 83 100 103 103 1501 10 27 28 40 5 7 27 29 30 39 40 42 42 45 67 80 0 5 45 59 10 20 22 23
output:
18
result:
ok single line: '18'
Test #4:
score: 0
Accepted
time: 0ms
memory: 3772kb
input:
1 1 1 0 1 0 1
output:
1
result:
ok single line: '1'
Test #5:
score: 0
Accepted
time: 0ms
memory: 3572kb
input:
1 10 2 1 2000 4 5 10 11 7 8 3 4 9 10 1 2 2 3 8 9 6 7 5 6
output:
10
result:
ok single line: '10'
Test #6:
score: 0
Accepted
time: 0ms
memory: 3816kb
input:
10 10 90 1440 1620 0 180 1080 1260 900 1080 180 360 720 900 540 720 360 540 1620 1800 1260 1440 1170 1350 990 1170 1530 1710 1350 1530 90 270 450 630 270 450 630 810 810 990 1710 1890
output:
20
result:
ok single line: '20'
Test #7:
score: 0
Accepted
time: 0ms
memory: 3600kb
input:
10 10 90 1080 1260 1440 1620 900 1080 1620 1800 180 360 360 540 540 720 1800 1980 1260 1440 720 900 90 270 1710 1890 810 990 1170 1350 1530 1710 630 810 1350 1530 990 1170 450 630 270 450
output:
20
result:
ok single line: '20'
Test #8:
score: 0
Accepted
time: 0ms
memory: 3604kb
input:
10 10 166 1 2 664 996 332 664 1660 1992 0 1 1328 1660 996 1328 3 4 2 3 4 5 333 334 1494 1826 498 830 1162 1494 334 335 336 337 0 332 830 1162 335 336 332 333
output:
20
result:
ok single line: '20'
Test #9:
score: 0
Accepted
time: 0ms
memory: 3636kb
input:
10 10 166 2 3 0 1 3 4 1328 1660 1999 2000 996 1328 1 2 332 664 4 5 664 996 334 335 335 336 333 334 1162 1494 0 332 498 830 336 337 830 1162 332 333 1999 2000
output:
19
result:
ok single line: '19'
Test #10:
score: -5
Wrong Answer
time: 0ms
memory: 3628kb
input:
10 10 1 1607 1721 327 413 222 264 1744 1746 35 50 619 766 995 1127 1421 1541 1236 1294 984 995 626 1122 1313 1386 65 141 1394 1428 1553 1764 1766 1990 1551 1552 465 531 1500 1531 623 625
output:
19
result:
wrong answer 1st lines differ - expected: '20', found: '19'
Subtask #2:
score: 0
Skipped
Dependency #1:
0%
Subtask #3:
score: 0
Wrong Answer
Test #104:
score: 6
Accepted
time: 0ms
memory: 3532kb
input:
1 1 1 0 1 0 1
output:
1
result:
ok single line: '1'
Test #105:
score: -6
Wrong Answer
time: 1ms
memory: 3592kb
input:
1 2000 2 999999996 1000000000 336 337 502 503 1906 1907 963 964 1351 1352 1795 1796 1510 1511 304 305 1930 1931 1735 1736 1469 1470 338 339 813 814 182 183 209 210 321 322 849 850 721 722 394 395 889 890 1758 1759 1440 1441 560 561 1470 1471 1916 1917 793 794 1366 1367 158 159 1602 1603 214 215 1119...
output:
1999
result:
wrong answer 1st lines differ - expected: '2000', found: '1999'
Subtask #4:
score: 0
Skipped
Dependency #1:
0%