西北大学集训队选拔赛(重现赛)——晾衣服

题目来源:牛客网
链接:https://ac.nowcoder.com/acm/contest/892/C
题目类型:贪心,二分
前言
由于我只看了贪心的解法,所以没有写二分的题解(二分:最小化最大值)
题目
在这里插入图片描述输入样例

2 10
100 10 100 1 1
10 3 5 2 3

输出样例

100

题解

  1. 用一个结构体来存入每一个衣服y的信息,包括题目所给的信息和每件衣服竖着放需要的时间times和横着放需要的时间timeh,还有两中情况的时间差cha最重要的是,求出需要的最大长度和sums,即全部竖着放的所需长度。
  2. 由最大答案一步步缩小时间。由于竖着放要的时间最长,所以我们首先求出全部竖着放情况的总时间sums,先假定每件衣服所需要的时间为它竖着放的时间即y[i].time=times。
  3. 开始下一步操作前先来一波特判,当晾衣绳长度小于竖着放总长度时,失败输出-1。如何符合要求则,按照每件衣服所需要的时间从大到小排序(因为,这个题目意思就是求最后干的衣服所需要的时间,即最大时间),再算出全部竖着放后剩余的长度yu=l-sums。
  4. 当上述步骤完成后,就只剩下贪心了,当:
    yu>y[i].cha时,y[i].time=y[i].timeh,然后yu=yu-y[i].cha,直到yu<=y[i].cha
  5. 最后求最大时间就OK了(滑稽.jpg)

代码

#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
struct yifu{
	ll a,b,c,d,e;
	ll timeh,times,cha,time;
};
bool cmp(yifu m,yifu n){
	return m.time>n.time;
}
int main(){
	yifu y[20001];
	int n,l,sumh=0,sums=0;
	cin  >> n >> l;
	for(int i=0;i<n;i++){
		scanf("%lld%lld%lld%lld%lld",&y[i].a,&y[i].b,&y[i].c,&y[i].d,&y[i].e);
		sumh+=y[i].b;
		y[i].timeh=(y[i].a+y[i].c-1)/y[i].c; //这里是一个小优化,防止出现舍去情况
		sums+=y[i].d; 
		y[i].times=(y[i].a+y[i].e-1)/y[i].e;
		y[i].time=y[i].times;
		y[i].cha=y[i].b-y[i].d;
	}
	if(l<sums){
		return !(cout << "-1");
	}
	ll yu=l-sums;
	sort(y,y+n,cmp);
	for(int i=0;i<n;i++){
		if(yu>=y[i].cha){
			y[i].time=y[i].timeh;
			yu-=y[i].cha;
		}
	}
	ll ans=0;
	for(int i=0;i<n;i++){
		ans=max(ans,y[i].time);
	}
	cout << ans << endl;
	return 0;
}
 
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值