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

相关推荐
测试199814 分钟前
简单的Web UI自动化测试框架Java实现
自动化测试·软件测试·selenium·测试工具·ui·职场和发展·测试用例
程序员小远19 分钟前
Selenium自动化测试之弹窗处理
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
feifeigo1231 小时前
MATLAB实现两组点云ICP配准
开发语言·算法·matlab
fengfuyao9851 小时前
粒子群算法(PSO)求解标准VRP问题的MATLAB实现
开发语言·算法·matlab
Ayanami_Reii1 小时前
进阶数据结构应用-SPOJ 3267 D-query
数据结构·算法·线段树·主席树·持久化线段树
天才测试猿2 小时前
Jmeter压测实战:Jmeter二次开发之自定义函数
自动化测试·软件测试·python·测试工具·jmeter·职场和发展·压力测试
guygg882 小时前
基于全变差的压缩感知视频图像重构算法
算法·重构·音视频
尋有緣2 小时前
力扣1327-列出指定时间段内所有的下单产品
leetcode·oracle·数据库开发
VT LI2 小时前
SDF在实时图形渲染中的核心原理与架构创新
算法·sdf·有号距离场
想七想八不如114082 小时前
408操作系统 PV专题
开发语言·算法