LeetCode、2300. 咒语和药水的成功对数【中等,排序+二分】

文章目录

前言

博主介绍:✌目前全网粉丝2W+,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技术领域。

涵盖技术内容:Java后端、算法、分布式微服务、中间件、前端、运维、ROS等。

博主所有博客文件目录索引:博客目录索引(持续更新)

视频平台:b站-Coder长路


LeetCode、2300. 咒语和药水的成功对数【中等,排序+二分】

来源:LeetCode专题《LeetCode 75》

题目及类型

题目链接:LeetCode、2300. 咒语和药水的成功对数

类型:基础算法/二分


思路及代码

思路:

首先对药水能量强度数组进行排序,接着我们去遍历所有的咒语,接着我们对药水能量数组进行二分,通过使用咒语与药水能量乘积来进行二分寻找边界值,来确定成功对数。

代码:

复杂度分析:时间复杂度O(n.logn);空间复杂度O(1)

java 复制代码
class Solution {

    //排序+二分
    //找到最右边不成功的组合的最后一个位置
    public int[] successfulPairs(int[] spells, int[] potions, long success) {
        int n = spells.length, m = potions.length;
        //结果数组
        int[] res = new int[n];
        //对potions升序
        Arrays.sort(potions);
        //遍历所有的药水
        for (int i = 0; i < n; i ++) {
            int ans = 0;
            //二分
            int l = 0, r = m - 1;
            while (l < r) {
                //若是拆分为[l, mid - 1]、[mid, r],那么一旦有r = mid - 1,需要+1为l + r + 1
                int mid = (l + r + 1) >> 1;
                // System.out.printf("mid=%d\n", mid);
                if (check(1L * spells[i] * potions[mid], success)) {
                    r = mid - 1;
                }else {
                    l = mid;
                }
            }
            //找到目标值
            // System.out.printf("%d %d\n", l, r);
            //全部成功(根据r的情况值来判定)
            if (r < 0 || (r == 0 && 1L * spells[i] * potions[0] >= success)) {
                ans = m;
            }else if (l >= m || (l == m - 1 && 1L * spells[i] * potions[m - 1] < success)) { //全部不匹配(根据l的情况值来判定)
                ans = 0;
            }else {
                //若是找到区间范围的
                ans = m - l - 1;
            }
            //将结果添加到结果集
            res[i] = ans;
        }
        return res;
    }

    //检测
    public boolean check(long cur, long success) {
        if (cur >= success) return true;
        return false;
    }

}

资料获取

大家点赞、收藏、关注、评论啦~

精彩专栏推荐订阅:在下方专栏👇🏻

更多博客与资料可查看👇🏻获取联系方式👇🏻,🍅文末获取开发资源及更多资源博客获取🍅


整理者:长路 整理时间:2024.1.19

相关推荐
Emilin Amy15 分钟前
【C++】【STL算法】那些STL算法替代的循环
开发语言·c++·算法·ros1/2
Hcoco_me30 分钟前
大模型面试题74:在使用GRPO训练LLM时,训练数据有什么要求?
人工智能·深度学习·算法·机器学习·chatgpt·机器人
天赐学c语言32 分钟前
1.16 - 二叉树的中序遍历 && 动态多态的实现原理
数据结构·c++·算法·leecode
AI前言观察者38 分钟前
2026年工作简历怎么写?
人工智能·经验分享·面试·职场和发展·求职招聘
sin_hielo1 小时前
leetcode 2975
数据结构·算法·leetcode
java修仙传1 小时前
力扣hot100:跳跃游戏
算法·leetcode·游戏
汉克老师1 小时前
GESP2025年9月认证C++三级真题与解析(单选题9-15)
c++·算法·数组·string·字符数组·gesp三级·gesp3级
发疯幼稚鬼1 小时前
简单介绍各类算法
算法
平生不喜凡桃李1 小时前
LeetCode:LRU and LFU
算法·leetcode·哈希算法
星诺算法备案1 小时前
算法备案中“落实算法安全主体责任”的实操构建
人工智能·算法·算法备案