news 2026/6/25 18:51:16

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/6/24 23:21:18

FF14自动跳过副本动画插件终极指南

FF14自动跳过副本动画插件终极指南 【免费下载链接】FFXIV_ACT_CutsceneSkip 项目地址: https://gitcode.com/gh_mirrors/ff/FFXIV_ACT_CutsceneSkip 还在为重复观看副本动画而烦恼吗&#xff1f;FF14玩家在日常刷副本时&#xff0c;常常需要手动跳过相同的过场动画&am…

作者头像 李华
网站建设 2026/6/25 8:49:52

基于微信小程序的社区老年服务系统毕业设计源码

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在设计并实现一款基于微信小程序的社区老年服务系统&#xff0c;以解决当前我国老龄化社会背景下社区老年人在生活、健康、娱乐等方面所面临的问题。具体…

作者头像 李华
网站建设 2026/6/24 17:53:01

统一场论质量定义方程:数学验证与应用分析

统一场论质量定义方程&#xff1a;数学验证与应用分析 引言 张祥前统一场论是一种基于空间几何运动的全新物理理论&#xff0c;旨在实现宏观与微观物理规律的自然统一。在该理论框架下&#xff0c;质量不再是物体的内禀属性&#xff0c;而是物体周围空间运动程度的度量。本文将…

作者头像 李华
网站建设 2026/6/25 21:45:13

10 Nacos 如何在集群中同步实例信息

在微服务架构中&#xff0c;服务发现与配置管理的核心诉求是数据一致性与服务可用性的动态平衡。然而由于分布式系统天然面临网络分区&#xff08;Partition Tolerance&#xff0c;P&#xff09;的不可控风险&#xff0c;CAP 原则又明确了三者不可兼得的铁律——在必须保障 P 的…

作者头像 李华
网站建设 2026/6/26 0:36:50

精选9款高效AI写作工具,帮助用户快速完成开题报告及学术论文创作。

毕业论文季的高效写作是许多学生的难题&#xff0c;传统人工写作费时费力&#xff0c;而AI工具能快速生成内容并优化重复率与AI痕迹。通过对9款平台的对比测试&#xff0c;可以筛选出最适合学术写作的智能助手。测试涵盖人工方法与AI工具的实际效果对比&#xff0c;并用真实数据…

作者头像 李华
网站建设 2026/6/25 1:50:26

2025年数字人厂家热销榜单:解锁最佳技术实力与落地方案

在数字科技迅猛发展的2025年&#xff0c;数字人行业迎来了前所未有的热潮。本篇文章将深入探讨2025年数字人厂家TOP5的评测&#xff0c;从技术实力到落地方案&#xff0c;带您全面了解这些厂商的优势与创新。在这个充满选择的市场中&#xff0c;揭晓最佳方案&#xff0c;让我们…

作者头像 李华