POJ 3614 Sunscreen 优先队列 贪心

题意

有C个奶牛去晒太阳 (1 <=C <= 2500),每个奶牛各自能够忍受的阳光强度有一个最小值和一个最大值,太大就晒伤了,太小奶牛没感觉。

而刚开始的阳光的强度非常大,奶牛都承受不住,然后奶牛就得涂抹防晒霜,防晒霜的作用是让阳光照在身上的阳光强度固定为某个值。

那么为了不让奶牛烫伤,又不会没有效果。

给出了L种防晒霜。每种的数量和固定的阳光强度也给出来了

每个奶牛只能抹一瓶防晒霜,最后问能够享受晒太阳的奶牛有几个。


那么将奶牛按照阳光强度的最小值从小到大排序。

将防晒霜也按照能固定的阳光强度从小到大排序


从最小的防晒霜枚举,将所有符合  最小值小于等于该防晒霜的 奶牛的 最大值 放入优先队列之中。

然后优先队列是小值先出

所以就可以将这些最大值中的最小的取出来。更新答案。

 

#include <iostream>

#include <algorithm>

#include <cstring>

#include <cstdio>

#include <map>

#include <vector>

#include <queue>

#define MAXN 2555

#define INF 1000000007

using namespace std;

int C, L;

typedef pair<int, int> P;

priority_queue<int, vector<int>, greater<int> > q;

P cow[MAXN], bot[MAXN];

int main()

{

    scanf("%d%d", &C, &L);

    for(int i = 0; i < C; i++) scanf("%d%d", &cow[i].first, &cow[i].second);

    for(int i = 0; i < L; i++) scanf("%d%d", &bot[i].first, &bot[i].second);

    sort(cow, cow + C);

    sort(bot, bot + L);

    int j = 0, ans = 0;

    for(int i = 0; i < L; i++)

    {

        while(j < C && cow[j].first <= bot[i].first)

        {

            q.push(cow[j].second);

            j++;

        }

        while(!q.empty() && bot[i].second)

        {

            int x = q.top();

            q.pop();

            if(x < bot[i].first) continue;

            ans++;

            bot[i].second--;

        }

    }

    printf("%d\n", ans);

    return 0;

}


 

 

你可能感兴趣的:(screen)