QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#621291 | #4419. Package Delivery | Odyssey | AC ✓ | 196ms | 6440kb | C++17 | 1.2kb | 2024-10-08 12:07:10 | 2024-10-08 12:07:14 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
typedef pair<int, int> PII;
const int N = 400010;
struct node
{
int l, r;
}s[N];
bool cmp(node x, node y)
{
//if (x.l == y.l)return x.r < y.r;
return x.l < y.l;
}
void sovle()
{
int n, k;
//cin >> n >> k;
scanf("%d%d", &n, &k);
for (int i = 1; i <= n; i++)
{
scanf("%d%d", &s[i].l, &s[i].r);
//cin >> s[i].l >> s[i].r;
}
sort(s + 1, s + 1 + n, cmp);
priority_queue < PII, vector<PII>, greater<PII>>q;
while (!q.empty())q.pop();
int t;
q.push({ s[1].r,s[1].l });
t = s[1].r;
int ans = 0;
for (int i = 2; i <=n;)
{
/*if (q.empty())
{
q.push({ s[i].r, s[i].l });
i++;
}
t = q.top().first;*/
while (i<=n&&(s[i].l <=t ||t==-1))
{
if (t == -1)t = s[i].r;
q.push({ s[i].r,s[i].l });
t = min(t, s[i].r);//important!
i++;
}
if (!q.empty())
{
ans++;
if (q.size() <= k)
{
while (!q.empty())q.pop();
t = -1;
}
else
{
int kk = k;
while (kk--)q.pop();
t = q.top().first;
}
}
}
ans += (q.size() + k - 1) / k;
/*cout << ans << endl;*/
printf("%d\n", ans);
}
int main()
{
int tt;
scanf("%d", &tt);
//cin >> tt;
while (tt--)
{
sovle();
}
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 196ms
memory: 6440kb
input:
2024 100 1 442460151 948559787 257924752 333997853 135225571 423096735 145956270 581316137 150642648 957750064 96771425 543507149 148750856 983838996 440403577 961685342 156399906 910285983 243714738 956235493 326220800 458442515 529302759 988863811 27258022 939870551 104136802 968000285 915165476 9...
output:
100 50 34 25 20 17 15 13 12 11 10 9 10 8 7 7 7 7 6 9 6 7 8 5 7 6 7 5 8 10 9 7 6 8 6 6 8 8 6 11 7 10 7 9 7 9 8 8 9 6 8 6 7 9 8 7 7 10 8 11 6 11 8 8 7 9 8 8 9 7 9 10 7 9 9 8 6 8 8 10 9 7 8 7 9 7 11 7 10 6 9 8 7 8 7 9 8 5 9 9 100 50 34 28 27 24 24 22 26 21 29 27 24 26 25 25 23 22 22 29 24 24 23 26 24 2...
result:
ok 2024 lines