问题 F: 放牛奶的冰箱--------------------------------------------思维(二分)

28 篇文章 0 订阅

题目描述
冬冬在古子城购买了一台冰箱,冰箱内部可以表示为高度为h,深度为1,宽度为2的矩阵,最初冰箱底部只有一个架子,但冬冬可以在任何一个格子顶部放隔板,隔板的宽为2,不占用任何空间,将冰箱内部分隔成上、下两部分。
冬冬有n瓶牛奶要按顺序放入冰箱里。第i瓶牛奶的高度是ai,深度和宽度均为1。如果架子上方的相应空间至少与瓶子一样高,他可以在一个架子上放一瓶牛奶,他不能将两瓶牛奶叠在一起(如果它们之间没有架子)。

上图为一个高为7,宽为2的冰箱,在高为5的位置放了一块隔板,冰箱内放了高3瓶牛奶,高度为3、5、2。
冬冬按顺序将牛奶往冰箱里放,他最多能往冰箱里放k瓶牛奶,他想知道k的值为多少?
输入
第一行包含两个整数n和h(1≤n≤106,1≤h≤106)表示牛奶的数量和冰箱的高度。
第二行包含n个整数a1,a2,…,an(1≤ai≤min(100,h))表示第i瓶牛奶的高度。
输出
输出k的值。
样例输入 Copy
【样例1】

5 7
2 3 5 4 1
【样例2】
10 10
9 1 1 1 1 1 1 1 1 1
【样例3】
5 10
3 1 4 2 4
样例输出 Copy
【样例1】

3
【样例2】
4
【样例3】
5
提示

解析:
一开始想到枚举,就立马想到二分了
二分选k个,因为是顺序取得,所以我们对前k个,从大到小排序贪心取如果第i个可以,那么第i+1个一定可以

#include<bits/stdc++.h>
using namespace std;
const int N=1e6+1000;
int a[N];
int b[N];
int h,n;
bool check(int x)
{
	int high=h;
	for(int i=1;i<=x;i++) b[i]=a[i];
	sort(b+1,b+1+x,greater<int>());
	int cnt=0;
	for(int i=1;i<=x;)
	{
		if(b[i]<=high)
		{
			if(i+1<=x) cnt+=2;
			else cnt+=1;
			high-=b[i];
			i+=2;
		}
		else break;
	}
	return cnt==x;
}
int main()
{
	scanf("%d %d",&n,&h);
	for(int i=1;i<=n;i++) cin>>a[i];
	int l=1,r=h;
	while(l<r)
	{
		int mid=l+r+1>>1;
		if(check(mid)) l=mid;
		else r=mid-1;
	 } 
	 cout<<l<<endl;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值