poj3614 Sunscreen(贪心+STL)

https://vjudge.net/problem/POJ-3614

如果这不是优先队列专题里的,我可能不一定能想到这么做。

结构体命名得有点不好,解题中看着Edge这个不恰当的命名,思路老是断掉。

贪心策略:先对牛按from升序,对瓶子按w升序,优先队列是按to的小顶堆;

    然后枚举瓶子,只要当前牛的from<=当前瓶子的w就入队,直到不满足为止;

    然后在队伍里取出一个,判断它的是否to>=w以及cover数是否还够用。

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<queue>
 4 #include<cstring>
 5 #include<algorithm>
 6 #include<cmath>
 7 #include<map>
 8 #define lson l, m, rt<<1
 9 #define rson m+1, r, rt<<1|1
10 #define INF 0x3f3f3f3f
11 typedef unsigned long long ll;
12 using namespace std;
13 int n, m;
14 struct Node{
15     int from, to;
16     int w;
17     friend bool operator<(const Node a, const Node b){
18         return a.to>b.to;//小顶堆按to排 
19     }
20 }node[3010];
21 struct Edge{
22     int w, cover;
23 }edge[3010];
24 bool cmp(const Edge a, const Edge b)
25 {
26     return a.w<b.w;
27 }
28 bool cmp2(const Node a, const Node b)
29 {
30     return a.from<b.from;
31 }
32 int main()
33 {
34     priority_queue<Node> q; 
35     cin >> n >> m;
36     for(int i = 0; i < n; i++){
37         cin >> node[i].from >> node[i].to;
38     }
39     for(int i = 0; i < m; i++){
40         cin >> edge[i].w >> edge[i].cover;
41     }
42     sort(edge, edge+m, cmp);
43     sort(node, node+n, cmp2);//一开始没加这个wa了好久 
44     int k = 0, ans=0;
45     for(int i = 0; i < m; i++){//瓶子 
46         while(k < n&&node[k].from<=edge[i].w){//左边界在它的前面就入队 
47             q.push(node[k]);
48             k++;
49         }
50         while(!q.empty()){
51             Node t = q.top(), p;
52             q.pop();
53             if(t.to>=edge[i].w&&edge[i].cover>0){//两种都满足可以ans++ 
54                 edge[i].cover--;
55                 ans++;
56             }
57             if(edge[i].cover == 0) break;
58             
59         }
60     }
61     cout << ans << endl;
62     return 0;
63 }

猜你喜欢

转载自www.cnblogs.com/Surprisezang/p/9028940.html