• 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
    ", ans);
        return 0;
    }
    


  • 相关阅读:
    java并发5-volatile关键字解析
    java并发4-单例设计方法
    Java并发3-多线程面试题
    JAVA并发2
    JAVA并发
    2015第27周三Java内存模型
    同一时候使用windows和linux系统
    深入浅出Windows BATCH
    DrawText的使用
    redmine忘记username和password
  • 原文地址:https://www.cnblogs.com/suncoolcat/p/3293928.html
Copyright © 2020-2023  润新知