POJ3104 二分

16 篇文章 0 订阅

题意:
有n件湿衣服,含水量分别为a[0~n-1],烘干机每分钟可以除去k份水,每过一分钟每件衣服自动蒸发1份水,注意在烘干的时候不会自动蒸发水

要点:
1.注意会超int,所以用long long(这里WA了很多次)
2.一个小技巧,整数运算中,a/b的上取整可以用(a+b-1)/b。
3.用二分枚举mid,如果一件衣服水量大于mid时,最短的时间是自动蒸发mid分钟,在烘干一段时间,为了将正在烘干的衣服也进入模型,采用(a[i]-mid)/(k-1),k-1中1是已经自然蒸发的量。这样把所有时间加起来比较即可

#include<stdio.h>
#include<string.h>
#define maxn 100000+5
int a[maxn];
int n, k;

bool check(long long mid)
{
    int i;
    long long num = 0;
    for (i = 0; i < n; i++)
    {
        if (a[i] - mid <= 0)//小于等于直接自动蒸发即可,不用烘干
            continue;
        if (k == 1)    //k=1直接退出循环看上面一步
            return false;    //只有刚好n个都小于等于mid时可以得到true得出结果
        num += (a[i] - mid+k-2) / (k-1);//向上取整的小技巧
    }   
    if (num > mid)  //从num+=a[i]-mid看,sum大了说明mid小了
        return false;
    else
        return true;//sum小了说明mid开大了
}


int main()
{   
    while (scanf("%d", &n) != EOF)
    {
        int i;
        long long left=0, right=0,mid; //注意容易超int
        for (i = 0; i < n; i++)
        {
            scanf("%d", &a[i]);
            right += a[i];
        }
        scanf("%d", &k);
        long long step=0;
        while (left <= right)
        {
            mid = (left + right) / 2;
            if (check(mid))
            {
                right = mid - 1;
                step = mid;
            }
            else    
                left = mid + 1;
        }
        printf("%I64d\n", step);
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值