当前位置: 首页 > 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.jsqmd.com/news/101615/

相关文章:

  • 巴菲特的投资时间管理
  • 文本消息发送:构造请求体、API 调用流程及 Go 语言的 Struct 映射实现
  • Motrix浏览器扩展:如何让你的下载速度提升300%?
  • 毕设 stm32与深度学习口罩佩戴检测系统(源码+硬件+论文)
  • 13、Linux文件系统挂载与检查全攻略
  • R 基础语法
  • A.每日一题——3562. 折扣价交易股票的最大利润
  • Obsidian Style Settings 终极指南:如何快速自定义你的笔记界面
  • TradingView图表库深度解析:实时数据流与K线生成实战指南
  • YOLOv11改进 - C3k2融合 | C3k2融合HMHA分层多头注意力机制(CVPR 2025):优化模型在复杂场景下的目标感知能力
  • 百度网盘解析:2025年最实用的下载限速终极解决方案
  • 大数据领域 Eureka 服务的性能瓶颈分析与突破
  • win11灵活控制Python版本,使用pyenv-win
  • 14、Linux 系统中光盘刻录与文件系统创建指南
  • 同样是PPT模板网站,为啥使用PPT模板 大家都选择LFPPT
  • 用户投诉处理指南:LobeChat建议妥善回应
  • Token 缓存策略对比:探讨本地内存、Redis 和数据库缓存的优缺点及适用场景
  • JavaScript for 循环详解
  • 应用页:专为电视与车机优化的轻量级应用管理解决方案
  • 15、Linux系统存储管理与RAID配置指南
  • 20、Mozilla 开发中的脚本、数据结构与数据库支持
  • LobeChat支持哪些大模型?一文看懂全兼容列表
  • 终极指南:免费部署Llama-2-7b-chat-hf打造企业级AI助手
  • Dolby Atmos Lite:轻量级全景声音效模拟工具,多设备音效增强方案
  • 抖音批量下载终极指南:5分钟掌握高效视频采集完整解决方案
  • 别再只知道 UUID 了!分布式 ID 生成方案大盘点与 Java 实现
  • 《Ionic 侧栏菜单》
  • 21、Mozilla数据库与文件格式详解
  • 阴阳师自动化脚本深度使用指南:从智能辅助到效率提升的完整解析
  • STL容器——vector容器