news 2026/4/16 11:58:00

D.二分查找-进阶——2300. 咒语和药水的成功对数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
D.二分查找-进阶——2300. 咒语和药水的成功对数

题目链接:2300. 咒语和药水的成功对数(中等)

算法原理:

解法一:暴力枚举(超时)

时间复杂度O(N²)

依次枚举每一个spellspotions的乘积,判断是否符合条件

解法二:二分查找

击败24.90%

时间复杂度O(Nlogn)

枚举每一个spells的同时对potions排序,这样才能够进行二分

那么符合题意的条件就变成了potions[mid]*spells[i]>=success,取的结果是大于等于,故采用“求最左端点”的模板,把所需的mid位置看成右区间的最左端点,如果没有最左端点就是最左端点右侧的值,这样都是能满足条件的

小细节:

①不要用t=(int)(success/spells[i])来作为目标值,因为整数除法会导致判断条件失效

②二分结束后,需要额外判断一下,因为此时left和right都停在了所需mid或者mid的右侧,但如果停在了最后一个位置,恰好最后一个位置的乘积也是<success,那么符合条件的计数就应该是0,而不是1

Java代码:

class Solution { //暴力解法 public int[] successfulPairs(int[] spells, int[] potions, long success) { int n=spells.length; int m=potions.length; int[] pairs=new int[n]; for(int i=0;i<n;i++){ int count=0; for(int x:potions){ long tmp=(long)spells[i]*x; if(tmp>=success) count++; } pairs[i]=count; } return pairs; } }
class Solution { //二分查找优化 public int[] successfulPairs(int[] spells, int[] potions, long success) { int n=spells.length; int m=potions.length; int[] pairs=new int[n]; Arrays.sort(potions); for(int i=0;i<n;i++){ int left=0,right=m-1; while(left<right){ int mid=left+(right-left)/2; if((long)potions[mid]*spells[i]<success) left=mid+1; else right=mid; } pairs[i]=(long)potions[left]*spells[i]>=success?m-left:0; } return pairs; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 16:36:32

3步搞定!Dart Simple Live包体积瘦身终极方案

"这直播App怎么这么大&#xff1f;都赶上游戏安装包了&#xff01;"——你是不是也经常听到用户这样的抱怨&#xff1f; 【免费下载链接】dart_simple_live 简简单单的看直播 项目地址: https://gitcode.com/GitHub_Trending/da/dart_simple_live 数据显示&am…

作者头像 李华
网站建设 2026/4/15 13:25:55

Springboot校园二手交易平台 99093(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。

系统程序文件列表项目功能&#xff1a;用户,卖家,商品分类,商品信息,在线咨询,商品需求开题报告内容SpringBoot校园二手交易平台开题报告一、研究背景与意义随着高等教育的普及和校园生活的日益丰富&#xff0c;大学生在学习和生活中产生了大量的二手物品&#xff0c;如书籍、电…

作者头像 李华
网站建设 2026/4/16 10:45:36

Springboot人力资源管理系统uynxv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。

系统程序件列表项目功能&#xff1a;员工,上班打卡,分配任务,完成任务,任务评价,工资信息,请假信息开题报告内容SpringBoot人力资源管理系统开题报告一、研究背景与意义&#xff08;一&#xff09;研究背景随着信息技术的飞速发展和互联网的普及&#xff0c;企业的人力资源管理…

作者头像 李华
网站建设 2026/4/16 10:38:54

Mac百度网盘终极加速方案:完整解锁SVIP极速下载体验

还在为百度网盘令人抓狂的下载速度而苦恼吗&#xff1f;每次看到进度条几乎不动&#xff0c;是不是都怀疑自己的网络出了问题&#xff1f;今天我要为你介绍一个专门针对macOS用户的终极解决方案&#xff0c;让你在几分钟内彻底告别限速困扰&#xff0c;享受与SVIP会员完全相同的…

作者头像 李华
网站建设 2026/4/13 10:26:49

UKB_RAP生物医学数据分析终极指南:从入门到精通

想要高效利用英国生物银行的海量数据资源吗&#xff1f;UKB_RAP&#xff08;英国生物银行研究应用平台&#xff09;为您提供了一套完整的生物医学数据分析解决方案。这个开源项目整合了基因组学、蛋白质组学等多组学分析工具&#xff0c;让复杂的数据分析变得简单易行。&#x…

作者头像 李华