当前位置: 首页 > article >正文

​LeetCode解法汇总2300. 咒语和药水的成功对数

目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台


描述:

给你两个正整数数组 spells 和 potions ,长度分别为 n 和 m ,其中 spells[i] 表示第 i 个咒语的能量强度,potions[j] 表示第 j 瓶药水的能量强度。

同时给你一个整数 success 。一个咒语和药水的能量强度 相乘 如果 大于等于 success ,那么它们视为一对 成功 的组合。

请你返回一个长度为 n 的整数数组 pairs,其中 pairs[i] 是能跟第 i 个咒语成功组合的 药水 数目。

示例 1:

输入:spells = [5,1,3], potions = [1,2,3,4,5], success = 7
输出:[4,0,3]
解释:
- 第 0 个咒语:5 * [1,2,3,4,5] = [5,10,15,20,25] 。总共 4 个成功组合。
- 第 1 个咒语:1 * [1,2,3,4,5] = [1,2,3,4,5] 。总共 0 个成功组合。
- 第 2 个咒语:3 * [1,2,3,4,5] = [3,6,9,12,15] 。总共 3 个成功组合。
所以返回 [4,0,3] 。

示例 2:

输入:spells = [3,1,2], potions = [8,5,8], success = 16
输出:[2,0,2]
解释:
- 第 0 个咒语:3 * [8,5,8] = [24,15,24] 。总共 2 个成功组合。
- 第 1 个咒语:1 * [8,5,8] = [8,5,8] 。总共 0 个成功组合。
- 第 2 个咒语:2 * [8,5,8] = [16,10,16] 。总共 2 个成功组合。
所以返回 [2,0,2] 。

提示:

  • n == spells.length
  • m == potions.length
  • 1 <= n, m <= 10^5
  • 1 <= spells[i], potions[i] <= 10^5
  • 1 <= success <= 1010

解题思路:

这题的spells.length, potions.length的范围是10^5,所以时间复杂度一定要小于O(n2)。最简单的降低时间复杂度的手段,就是二分查找,可以从n2降底到n*logN。

所以针对potions进行排序,然后进行二分查找尝试,找到最小的复合条件的值的位置。比如[1,2,3,4,5],假设符合条件的最小值是2,其位置是1,那么这行复合条件的数量就是5-1=4。

代码:

public class Solution2300 {

    public int[] successfulPairs(int[] spells, int[] potions, long success) {
        int length = potions.length;
        int[] result = new int[spells.length];
        Arrays.sort(potions);
        for (int i = 0; i < spells.length; i++) {
            long value = spells[i];
            int left = 0;
            int right = length - 1;
            int abs = length;
            while (left <= right) {
                int middle = (left + right) / 2;
                if (value * potions[middle] >= success) {
                    abs = middle;
                    right = middle - 1;
                } else {
                    left = middle + 1;
                }
            }
            result[i] = length - abs;
        }
        return result;
    }

}


http://www.kler.cn/a/136058.html

相关文章:

  • 缓存-Redis-数据结构-redis哪些数据结构是跳表实现的?
  • 大华前端开发面试题及参考答案 (下)
  • 第三部分:Linux中的yum
  • < OS 有关 > 阿里云:轻量应用服务器 的使用 安装 Tailscale 后DNS 出错, 修复并替换 apt 数据源
  • Android系统开发(六):从Linux到Android:模块化开发,GKI内核的硬核科普
  • AI需要的基础数学知识
  • kubernetes v1.24.7 + docker
  • Map 和 WeakMap:JavaScript 中的键值对集合
  • EI论文程序:Adaboost-BP神经网络的回归预测算法,可作为深度学习对比预测模型,丰富实验内容,自带数据集,直接运行!
  • 数据库管理工具,你可以用Navicat,但我选DBeaver!
  • vue3 setup展示数据
  • Unity 场景烘培 ——unity Post-Processing后处理1(四)
  • ClickHouse的 MaterializeMySQL引擎
  • Linux进程通信——IPC、管道、FIFO的引入
  • 电容的耐压值是什么意思呢?
  • Midjourney绘画提示词Prompt参考学习教程
  • Mysql-复合查询
  • RuntimeError: PyPI no longer supports ‘pip search‘ (or XML-RPC search).
  • 04.webpack中css的压缩和抽离
  • ClickHouse 物化视图
  • 【mediasoup】TransportCongestionControlClient 1: 代码走读
  • Vue 2.0的源码构建
  • 负载均衡简介
  • mysql5.6 删除用户/ drop user
  • python django 小程序图书借阅源码
  • 华纳云服务器怎么清理cdn缓存?