mirror of
https://git.sb/baoshuo/OI-codes.git
synced 2024-12-28 14:11:58 +00:00
1456. Supermarket
22873420
This commit is contained in:
parent
c7279f8669
commit
fc73dada0b
40
POJ/1456/1456.cpp
Normal file
40
POJ/1456/1456.cpp
Normal file
@ -0,0 +1,40 @@
|
||||
#include <algorithm>
|
||||
#include <iostream>
|
||||
#include <queue>
|
||||
|
||||
using namespace std;
|
||||
|
||||
struct node {
|
||||
int expire, value;
|
||||
|
||||
const bool operator<(const node& b) const {
|
||||
return expire > b.expire;
|
||||
}
|
||||
} a[10005];
|
||||
|
||||
int main() {
|
||||
int n;
|
||||
while (cin >> n) {
|
||||
int d = 1, ans = 0;
|
||||
priority_queue<int> q;
|
||||
for (int i = 0; i < n; i++) {
|
||||
cin >> a[i].value >> a[i].expire;
|
||||
}
|
||||
sort(a, a + n);
|
||||
a[n].value = a[n].expire = 0;
|
||||
for (int i = 0; i < n;) {
|
||||
int last = a[i].expire;
|
||||
while (a[i].expire == last) {
|
||||
q.push(a[i++].value);
|
||||
}
|
||||
int lim = last - a[i].expire;
|
||||
while (q.size() && lim) {
|
||||
ans += q.top();
|
||||
q.pop();
|
||||
lim--;
|
||||
}
|
||||
}
|
||||
cout << ans << endl;
|
||||
}
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue
Block a user