【每日一题】2809. 使数组和小于等于 x 的最少时间-2024.1.19

题目:

2809. 使数组和小于等于 x 的最少时间

给你两个长度相等下标从 0 开始的整数数组 nums1nums2 。每一秒,对于所有下标 0 <= i < nums1.lengthnums1[i] 的值都增加 nums2[i] 。操作 完成后 ,你可以进行如下操作:

  • 选择任一满足 0 <= i < nums1.length 的下标 i ,并使 nums1[i] = 0

同时给你一个整数 x

请你返回使 nums1 中所有元素之和 小于等于 x 所需要的 最少 时间,如果无法实现,那么返回 -1

示例 1:

复制代码
输入:nums1 = [1,2,3], nums2 = [1,2,3], x = 4
输出:3
解释:
第 1 秒,我们对 i = 0 进行操作,得到 nums1 = [0,2+2,3+3] = [0,4,6] 。
第 2 秒,我们对 i = 1 进行操作,得到 nums1 = [0+1,0,6+3] = [1,0,9] 。
第 3 秒,我们对 i = 2 进行操作,得到 nums1 = [1+1,0+2,0] = [2,2,0] 。
现在 nums1 的和为 4 。不存在更少次数的操作,所以我们返回 3 。

示例 2:

复制代码
输入:nums1 = [1,2,3], nums2 = [3,3,3], x = 4
输出:-1
解释:不管如何操作,nums1 的和总是会超过 x 。

提示:

  • 1 <= nums1.length <= 103
  • 1 <= nums1[i] <= 103
  • 0 <= nums2[i] <= 103
  • nums1.length == nums2.length
  • 0 <= x <= 106

解答:

代码:

复制代码
class Solution {
    public int minimumTime(List<Integer> nums1, List<Integer> nums2, int x) {
        int n=nums1.size(),s1=0,s2=0;
        int[] dp=new int[n+1];
        List<List<Integer>> nums=new ArrayList<>();
        for(int i=0;i<n;i++){
            int a=nums1.get(i),b=nums2.get(i);
            nums.add(Arrays.asList(b,a));
            s1+=a;
            s2+=b;
        }
        Collections.sort(nums,(o1,o2)->Integer.compare(o1.get(0),o2.get(0)));
        for(int j=1;j<=n;j++){
            int b=nums.get(j-1).get(0),a=nums.get(j-1).get(1);
            for(int i=j;i>0;i--){
                dp[i]=Math.max(dp[i],dp[i-1]+i*b+a);
            }
        }
        for(int i=0;i<=n;i++){
            if(s2*i+s1-dp[i]<=x){
                return i;
            }
        }
        return -1;
    }
}

结果:

相关推荐
NAGNIP17 小时前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
美团技术团队18 小时前
LongCat-Flash:如何使用 SGLang 部署美团 Agentic 模型
人工智能·算法
Fanxt_Ja1 天前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
侃侃_天下1 天前
最终的信号类
开发语言·c++·算法
茉莉玫瑰花茶1 天前
算法 --- 字符串
算法
博笙困了1 天前
AcWing学习——差分
c++·算法
NAGNIP1 天前
认识 Unsloth 框架:大模型高效微调的利器
算法
NAGNIP1 天前
大模型微调框架之LLaMA Factory
算法
echoarts1 天前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Python技术极客1 天前
一款超好用的 Python 交互式可视化工具,强烈推荐~
算法