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

D.二分查找-二分答案-求最小——1283. 使结果不超过阈值的最小除数

题目链接:1283. 使结果不超过阈值的最小除数(中等)

算法原理:

解法:二分查找

6ms击败94.13%

时间复杂度O(n×log(max_num))

因为是找最小,在左边,因此选用最左端点模型

①题目没说一定升序,且除数一旦大于最大值,之后结果都是1,因此right要取数组中的最大值,需要O(N)时间复杂度的一次遍历

②分析要找的目标值,来分析left和right最终的位置,写出判断方法check,判断当前mid作为除数是否符合<=t的条件

③如果mid在最左端点的左边,那么left=mid+1,此时分析check方法,分析如上图,对应的值应该是false

④咱们要找的就是未知的符合条件的最左端点,所以left最终的位置即答案,无需分析第二落到的位置

⑤小细节:left初始化为1,因为当最左端点就是left落到的位置时,0不能做除数,除数最小也是1

Java代码:

class Solution { public int smallestDivisor(int[] nums, int t) { //除数不能是0,所以left初始化为1 int left=1,right=0; for(int x:nums) right=Math.max(x,right); //找除数最小:最左端点模型 while(left<right){ int mid=left+(right-left)/2; if(!check(nums,mid,t)) left=mid+1; else right=mid; } return left; } private boolean check(int[] nums,int mid,int t){ int sum=0; for(int x:nums){ //+mid-1:补足余数,完成向上取整 sum+=(x+mid-1)/mid; if(sum>t) return false; } return true; } }
http://www.rkmt.cn/news/112412.html

相关文章:

  • 文本消息发送:构造请求体、API 调用流程及 Go 语言的 Struct 映射实现
  • 毕设 stm32与深度学习口罩佩戴检测系统(源码+硬件+论文)
  • R 基础语法
  • YOLOv11改进 - C3k2融合 | C3k2融合HMHA分层多头注意力机制(CVPR 2025):优化模型在复杂场景下的目标感知能力
  • win11灵活控制Python版本,使用pyenv-win
  • 大数据领域 Eureka 服务的性能瓶颈分析与突破
  • Token 缓存策略对比:探讨本地内存、Redis 和数据库缓存的优缺点及适用场景
  • 15、Linux系统存储管理与RAID配置指南
  • 抖音批量下载终极指南:5分钟掌握高效视频采集完整解决方案
  • STL容器——vector容器
  • 人工智能在健康医疗软件中的应用
  • 一段代码带你理解输入缓冲区
  • 5步搞定SillyTavern版本升级:告别烦恼的完整指南
  • 16、深入了解Linux存储与设备管理
  • 如何获取美股实时行情:Python 量化交易指南
  • PHP 常量
  • Linux学习日记21:读写锁
  • 15、深入探索Vim寄存器:复制粘贴的高级技巧
  • 基于C#的FTP客户端实现方案
  • 16、Vim 复制粘贴与宏操作技巧全解析
  • ArcGIS中的字段类型
  • 移动端AI绘图:iPhone上实现3秒内图像生成的完整技术方案
  • 9、Vim 中运行 shell 命令及文件管理全解析
  • 《C语言电子新-2026最新版》-编程语言与程序
  • RocketMQ 高并发场景优化:消息压缩、批量发送与消费线程池调优
  • 5分钟掌握:安卓防撤回黑科技,从此不再错过任何重要信息
  • 11、Vim 文件操作与移动技巧全解析
  • allegro工艺边的制作和mark点放置
  • 旅行攻略助手:LobeChat规划完美行程
  • Beyond Compare 5完整激活指南:从问题排查到成功授权