目录

爱吃香蕉的珂珂

题目链接

爱吃香蕉的珂珂

题目描述

注意点

  • piles.length <= h <= 10^9
  • 如果某堆香蕉少于k根,将吃掉这堆的所有香蕉,然后这一小时内不会再吃更多的香蕉
  • 返回可以在 h 小时内吃掉所有香蕉的最小速度 k(k 为整数)

解答思路

  • 二分查找找到在 h 小时内吃掉所有香蕉的最小速度k,已知珂珂保证在h小时内吃完所有香蕉时最快速度max为Math.max(piles),吃香蕉的最慢速度min为1(但是不保证在h小时内能吃完所有香蕉),min和max就是二分查找的左右边界,在二分查找时,每次找到左右边界的中间点mid判断mid速度能否在h小时内吃完,如果能则max = mid - 1,如果不能则min = mid + 1,找到满足吃完香蕉的最慢速度即可

代码

java 复制代码
class Solution {
    public int minEatingSpeed(int[] piles, int h) {
        int min = 1;
        int max = 0;
        for (int pile : piles) {
            max = Math.max(max, pile);
        }
        while (min <= max) {
            int mid = min + (max - min >> 1);
            long time = 0;
            for (int pile : piles) {
                // 不能整除则向上取整
                time += (pile + mid - 1) / mid;
            }
            if (time > h) {
                min = mid + 1;
            } else {
                max = mid - 1;
            }
        }
        return min;
    }
}

关键点

  • 二分查找的思想
  • 如果某堆香蕉少于k根,将吃掉这堆的所有香蕉,然后这一小时内不会再吃更多的香蕉
  • 找到在h小时内吃完所有香蕉的最慢速度
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
夜羽rancho3 分钟前
二分查找,其实就这些了
前端·算法
桦说编程4 分钟前
告别强制转换:使用设计模式实现 Guava ListenableFuture 与 TTL 优雅融合
java·后端·设计模式
天天扭码5 分钟前
一分钟解决 | 高频面试算法题——接雨水(双指针最优解)
前端·算法·面试
Cachel wood11 分钟前
大数据开发知识1:数据仓库
android·大数据·数据仓库·sql·mysql·算法·ab测试
珹洺16 分钟前
Jsp技术入门指南【九】详细讲解JSTL
java·linux·开发语言·前端·jsp
小智疯狂敲代码18 分钟前
Spring AOP 源码-通知链的执行与责任链模式
java·面试
独行soc20 分钟前
2025年渗透测试面试题总结-拷打题库06(题目+回答)
java·开发语言·前端·中间件·数据挖掘·php·xss
灰色人生qwer21 分钟前
idea中运行groovy程序报错
android·java·intellij-idea
能源恒观21 分钟前
彻底弄懂Spring MVC常用注解
java·后端
重楼七叶一枝花21 分钟前
ThreadLocal - 原理与应用场景详解
java·后端