【每日一题】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;
    }
}

结果:

相关推荐
Dlrb12118 小时前
C语言-指针三
c语言·算法·指针·const·命令行参数
Tisfy8 小时前
LeetCode 2540.最小公共值:双指针(O(m+n))
算法·leetcode·题解·双指针
IronMurphy8 小时前
【算法四十七】152. 乘积最大子数组
算法
淘矿人9 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
Cosolar9 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
小江的记录本9 小时前
【Java基础】泛型:泛型擦除、通配符、上下界限定(附《思维导图》+《面试高频考点清单》)
java·数据结构·后端·mysql·spring·面试·职场和发展
落羽的落羽11 小时前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
萑澈11 小时前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl
Godspeed Zhao12 小时前
从零开始学AI16——SVM
算法·机器学习·支持向量机