陶陶摘苹果(升级版)
又是一年秋季时,陶陶家的苹果树结了n个果子。陶陶又跑去摘苹果,这次他有一个a公分的椅子。当他手够不着时,他会站到椅子上再试试。这次与 NOIp2005 普及组第一题不同的是:陶陶之前搬凳子,力气只剩下s了。当然,每次摘苹果时都要用一定的力气。陶陶想知道在s0之前最多能摘到多少个苹果。现在已知n个苹果到达地上的高度xi,椅子的高度a,陶陶手伸直的最大长度b,陶陶所剩的力气s,陶陶摘一个苹果需要的力
P1478 陶陶摘苹果(升级版)
题目描述
又是一年秋季时,陶陶家的苹果树结了 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。
代码内容
// #include <iostream>
// #include <algorithm>
// #include <cstring>
// #include <stack>//栈
// #include <deque>//堆
// #include <queue>//队列
// #include <map>//映射
// #include <unordered_map>//哈希表
// #include <vector>//容器,存数组的数,表数组的长度
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
vector<ll> v;
int main()
{
ll n,s,a,b;
cin>>n>>s>>a>>b;
while(n--)
{
ll x,y;
cin>>x>>y;
if(x<=a+b) v.push_back(y);
}
sort(v.begin(),v.end());
ll ans=0;
for(auto &t:v)
{
s-=t;
if(s<0) break;
ans++;
}
cout<<ans<<endl;
return 0;
}
更多推荐



所有评论(0)