我要感谢作者给我们降低难度
新人第一篇题解awa
因为NOIP2005的原题还要考虑搬椅子
但是这道题非常贴心地说去年椅子搬好了,然后解题组直接欢呼一片
不扯淡了
这道题呢一道典型的贪心
由于苹果有两个指标《高度,摘下来所需的力气》
因此我们需要一个结构体(不知道结构体是啥的自己补课)
并且声明一个tree数组(存数据)
直接贴代码
struct apple{
int high,strength;
}tree[5001];
然后我们做一个灰常简单的输入
【声明地变量分别代表 果子数量,陶陶力气,手长,椅子高度,
还有答案陶陶最多可以摘的苹果】
int n,s,a,b,sum=0;
cin>>n>>s>>a>>b;
for(int i=0;i<n;i++){
cin>>tree[i].high>>tree[i].strength;
}
正片开始
我们接下来要看一下这个灰常简单的主循环【就这一个】 真的简单
我们要先排序一下,让这棵树变得非常有序
由于运算符重载对sort在不同编译器里有区别,因此直接写一个cmp
这里比较优先级是先是耗费的力气,然后是高度
bool cmp(apple x,apple y){
if(x.strength!=y.strength){
return x.strength<y.strength;
}else{
return x.high<y.high;
}
}
然后再排序一下
sort(tree,tree+n,cmp);
正片刚刚早就开始了
因为树已经是有序的了,所以我们只要遍历一下就好了
for(int i=0;i<n;i++)
摘苹果的标准是高度可以够得到(手+椅子)
并且还有体力就可以了
if(tree[i].high<=a+b&&tree[i].strength<=s){
s-=tree[i].strength;
sum++;
}
然后出现else的情况有两种 1:高度不够 2:力气没了
由于力气没了后面要的力气可能会更多,
因此直接break
else if(tree[i].strength>s){
break;
}
我们还要考虑高度不够【因为我们排序规则是以耗费的力气为优先级的】
高度不够并不代表你可以break
好了 到这里,你就完全理解这道题了
贴代码
#include<bits/stdc++.h>
using namespace std;
struct apple{
int high,strength;
}tree[5001];
bool cmp(apple x,apple y){
if(x.strength!=y.strength){
return x.strength<y.strength;
}else{
return x.high<y.high;
}
}
int main(){
int n,s,a,b,sum=0;
cin>>n>>s>>a>>b;
for(int i=0;i<n;i++){
cin>>tree[i].high>>tree[i].strength;
}sort(tree,tree+n,cmp);
for(int i=0;i<n;i++){
if(tree[i].high<=a+b&&tree[i].strength<=s){
s-=tree[i].strength;
sum++;
}else if(tree[i].strength>s){
break;
}
}cout<<sum;
return 0;
}
《我添加了防抄袭awa》