POJ3614,P2887-Sunscreen(防晒霜)【贪心】
生活随笔
收集整理的這篇文章主要介紹了
POJ3614,P2887-Sunscreen(防晒霜)【贪心】
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
正題
POJ題目鏈接:http://poj.org/problem?id=3614
luogu評測記錄:https://www.luogu.org/recordnew/lists?uid=52918&pid=P2887
題目大意
有n頭牛,每個牛對陽光有上下限制的要求,有m種防曬霜,可以將牛的陽光固定在一個值,防曬霜有數(shù)量限制,求最多可以滿足多少頭牛。
解題思路
我們可以將對陽光的要求下限從大到小排序。然后對于每頭牛,能滿足的就滿足,因為每頭牛對于答案的貢獻是一樣的。之后我們按順序?qū)τ诿款^牛就給他分配最大的防曬霜,因為這樣對于后面的牛的影響是最小的。
code
#include<cstdio> #include<algorithm> using namespace std; struct cow{int mif,maf; }co[3501]; struct Spf{int spf,cs; }sp[3501]; int n,m,s; bool cmp1(cow x,cow y) {return x.mif==y.mif?x.maf>y.maf:x.mif>y.mif; } bool cmp2(Spf x,Spf y) {return x.spf>y.spf; } int main() {scanf("%d%d",&n,&m);for (int i=1;i<=n;i++)scanf("%d%d",&co[i].mif,&co[i].maf);for (int i=1;i<=m;i++)scanf("%d%d",&sp[i].spf,&sp[i].cs);sort(co+1,co+1+n,cmp1);//排序sort(sp+1,sp+1+m,cmp2);for (int i=1;i<=n;i++){for (int j=1;j<=m;j++)//尋找防曬霜if (sp[j].cs>0&&sp[j].spf<=co[i].maf&&sp[j].spf>=co[i].mif){sp[j].cs--;s++;break;}}printf("%d",s); }總結(jié)
以上是生活随笔為你收集整理的POJ3614,P2887-Sunscreen(防晒霜)【贪心】的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 自定义一个监控自定义一个监控系统
- 下一篇: 华为手机如何共享网络给华为路由器华为路由