leetcode 2300. 咒语和药水的成功对数

题目如下

数据范围

示例

复制代码
注意到n和m的长度最长达到10的5次方所以时间复杂度为n方的必然超时。
因为题目要求我们返回每个位置的spell对应的有效对数所以我们只需要找到第一个有效的药水就行,这里可以先对potions排序随后使用二分查找把时间复杂度压到nlogn就不会超时。

通过代码

cpp 复制代码
class Solution {
public:
       int findl(vector<int>& nums,long long v,long long target){
        int n = nums.size();
        int l = 0,r = n - 1;
        int mid = (l + r) / 2;
        
        
        while(l < r){
            if(v * nums[mid] >= target){
                r = mid;
            }else{
                l = mid + 1;
            }
            mid = (l + r) / 2;
        }
        if(v * nums[l] < target)return 0;
        return n - l;
        
        
    }
    vector<int> successfulPairs(vector<int>& spells, vector<int>& potions, long long success) {
         int n = spells.size(); 
         sort(potions.begin(),potions.end());
         vector<int> ans;
         for(int i = 0;i < n;i++){
                ans.emplace_back(findl(potions,spells[i],success));
         }
         return ans;
    }
};
相关推荐
EdmundXjs11 分钟前
大模型核心概念解读
人工智能·算法
lookaroundd13 分钟前
llm-compressor 普通量化调用链分析
python·算法
小羊在睡觉27 分钟前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go
兰令水30 分钟前
topcode【随机算法题】【2026.5.20打卡-java版本】
java·开发语言·算法
不吃土豆的马铃薯37 分钟前
Spdlog 入门:日志记录器与日志槽基础详解
服务器·开发语言·c++·c·日志·spdlog
此生决int40 分钟前
算法从入门到精通——前缀和
c++·算法·蓝桥杯
我星期八休息1 小时前
Linux系统编程—库制作与原理
linux·运维·服务器·数据结构·人工智能·python·散列表
大大杰哥1 小时前
leetcode hot100(4)矩阵
算法·leetcode·矩阵
Fuyo_11191 小时前
C++中的活字印刷术——模板·初阶
开发语言·c++·笔记
小白|1 小时前
cmake:昇腾CANN构建系统完全指南
java·c++·算法