当前位置: 首页 > news >正文

875、爱吃香蕉的珂珂

题目:

解答:

h为k的单调不增加函数,因此可以通过查找k的位置来获得k。k的范围应当是[1,max(piles[i])]

使用二分查找来确定位置,这里的时间复杂度是log(max(piles[i])),后续写成logm,m记为最大值

判断条件:吃的时间h小于k。h的计算需要通过遍历piles数组计算。每个piles[i],吃的时间应该是(piles[i]-1)/k。累加判断是否超过即可,注意溢出。判断其是否超过h,套二分的模板即可。

class Solution {
public:int minEatingSpeed(vector<int>& piles, int h) {int n = piles.size();int left = 1, right = *max_element(piles.begin(), piles.end());if (n == h)return right;int mid = right + (left - right) / 2;while (left <= right) {long ans = 0;for (int i = 0; i < n; i++) {ans += (piles[i] - 1) / mid + 1;}if (ans > h) {left = mid + 1;} else {right = mid - 1;}mid = left + (right - mid) / 2;}return left;}
};

时间复杂度O(nlogm)

空间复杂度O(1)

http://www.dtcms.com/a/269521.html

相关文章:

  • 吃透二分法的模板解法(适合所有类似于二分的算法题)
  • 百度斩获大模型中标第一,股价上涨5%
  • 深度剖析:Ceph分布式存储系统架构
  • 实时开发IDE部署指南
  • Tomcat与IIS:核心差异及接口调用实战解析
  • paddlehub环境搭建和测试
  • 【PTA数据结构 | C语言版】在顺序表 list 的第 i 个位置上插入元素 x
  • C语言使用Protobuf进行网络通信
  • HTTP/3.0的连接迁移使用连接ID来标识连接为什么可以做到连接不会中断
  • 【论文阅读】基于 GAN 和深度迁移学习的频谱预测:一种跨带数据增强框架
  • 函数-1-字符串函数
  • Python文件操作(五分钟小白从入门到精通)
  • 微算法科技(NASDAQ MLGO)研究非标准量子预言机,拓展量子计算边界
  • 【QT】-隐式转换 explicit用法
  • linux常用管路命令
  • 【1-快速上手】
  • 部署并运行Spike-Driven-Transformer或QKFormer
  • 香港站群服务器与普通香港服务器对比
  • 算法设计与分析:分治、动态规划与贪心算法的异同与选择
  • 【计算机网络】第三章:数据链路层(下)
  • 89104 PCIe Switch芯片国产替代 - PCIE5.0国产AI服务器高性能扩展,支持海光/龙芯/飞腾等
  • 【零基础学AI】第30讲:生成对抗网络(GAN)实战 - 手写数字生成
  • 从SEO到GEO:优化策略如何应对传统搜索与AI搜索的巨变
  • SpringAI编码实战:使用本地免费部署的大语言模型跑起来
  • NuxtJS中网络请求模块的封装与最佳实战
  • leetcode202.快乐数
  • 算法设计与分析 知识总结
  • Puppeteer 库简介:背景、用法与原理
  • LeetCode--42.接雨水
  • 什么是RAG?