陶陶摘苹果(升级版)
题目描述
又是一年秋季时,陶陶家的苹果树结了 nnn 个果子。陶陶又跑去摘苹果,这次他有一个 aaa 公分的椅子。当他手够不着时,他会站到椅子上再试试。
这次与 NOIp2005 普及组第一题不同的是:陶陶之前搬凳子,力气只剩下 sss 了。当然,每次摘苹果时都要用一定的力气。陶陶想知道在 s<0s<0s<0 之前最多能摘到多少个苹果。
现在已知 nnn 个苹果到达地上的高度 xix_ixi,椅子的高度 aaa,陶陶手伸直的最大长度 bbb,陶陶所剩的力气 sss,陶陶摘一个苹果需要的力气 yiy_iyi,求陶陶最多能摘到多少个苹果。
输入格式
第 111 行:两个数 苹果数 nnn,力气 sss。
第 222 行:两个数 椅子的高度 aaa,陶陶手伸直的最大长度 bbb。
第 333 行~第 3+n−13+n-13+n−1 行:每行两个数 苹果高度 xix_ixi,摘这个苹果需要的力气 yiy_iyi。
输出格式
只有一个整数,表示陶陶最多能摘到的苹果数。
样例 #1
样例输入 #1
8 15
20 130
120 3
150 2
110 7
180 1
50 8
200 0
140 3
120 2
样例输出 #1
4
提示
对于 100%100\%100% 的数据,n≤5000n\leq 5000n≤5000, a≤50a\leq 50a≤50, b≤200b\leq 200b≤200, s≤1000s\leq 1000s≤1000, xi≤280x_i\leq 280xi≤280, yi≤100y_i\leq 100yi≤100。
代码实现
//由题可知,我们先可以对能够得到的apple先排序,够不到的全部不要
#include<iostream>
#include<algorithm>
#include<vector>
#define x first
#define y second
using namespace std;
typedef pair<int,int> PII;
vector<PII> w;
int n,S,a,b;
int main(){
cin>>n>>S>>a>>b;
for(int i=1;i<=n;i++){
int l,r;
cin>>l>>r;
if(l>a+b)continue;
w.push_back({r,l});//按照力气排序
}
sort(w.begin(),w.end());
int res=0;
for(auto q:w){
if(S<0){
break;
}
if(q.x<=S){
S-=q.x;
res++;
}
}
cout<<res;
return 0;
}
该篇文章探讨了一个关于计算陶陶在体力限制下能摘取苹果数量的问题,通过输入参数如苹果数量、椅子高度等进行分析。
&spm=1001.2101.3001.5002&articleId=136520217&d=1&t=3&u=68c7dba6a7a9406e945f5582f85490f8)
1383

被折叠的 条评论
为什么被折叠?



