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+n1 行:每行两个数 苹果高度 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 5000n5000, a≤50a\leq 50a50, b≤200b\leq 200b200, s≤1000s\leq 1000s1000, xi≤280x_i\leq 280xi280, yi≤100y_i\leq 100yi100

代码内容

// #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;
}
Logo

集算法之大成!助力oier实现梦想!

更多推荐