陶陶摘苹果(升级版)题解《洛谷发题解被卡了》

我要感谢作者给我们降低难度

新人第一篇题解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》

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值