Leetcode刷题详解——将x减到0的最小操作数

1. 题目链接:1658. 将 x 减到 0 的最小操作数

2. 题目描述:

给你一个整数数组 nums 和一个整数 x 。每一次操作时,你应当移除数组 nums 最左边或最右边的元素,然后从 x 中减去该元素的值。请注意,需要 修改 数组以供接下来的操作使用。

如果可以将 x 恰好 减到 0 ,返回 最小操作数 ;否则,返回 -1

示例 1:

复制代码
输入:nums = [1,1,4,2,3], x = 5
输出:2
解释:最佳解决方案是移除后两个元素,将 x 减到 0 。

示例 2:

复制代码
输入:nums = [5,6,7,8,9], x = 4
输出:-1

示例 3:

复制代码
输入:nums = [3,2,20,1,1,3], x = 10
输出:5
解释:最佳解决方案是移除后三个元素和前两个元素(总共 5 次操作),将 x 减到 0 。

提示:

  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 104
  • 1 <= x <= 109

3. 解法(滑动窗口):

3.1 算法思路:

先计算出最长数组,用总长度减去减去最长数组,如果恰好减到0,返回最小操作数;否则返回-1

3.2 算法流程:

  1. 转化问题:求target=sum-x。如果target<0,直接返回-1

  2. right小于数组长度时,一直循环:

    • 如果tmp<target,右移右指针,直至变量和大于等于target,或右指针已经移到了头

    • 如果tmp>target,右移左指针,直至变量和大小等于target,或左指针已经移到了头

    • 如果经过前两步的左右移动使得tmp==target,维护满足条件数组的最大长度,并让下个元素进入窗口

    • 循环结束后,返回结果

c++ 复制代码
class Solution {
public:
    int minOperations(vector<int>& nums, int x) {
        int sum=0;
        int ret=-1;
        int left=0,right=0;
        int tmp=0;
        //计算所有元素的和
        for(int i=0;i<nums.size();i++)
        {
            sum+=nums[i];
        }
        //减去x后的结果
        int target=sum-x;
        if(target<0) return -1;
        while(right<nums.size())
        {
            //进窗口
            tmp+=nums[right];
            //判断
            while(tmp>target)
            //窗口
            tmp-=nums[left++];
             //更新结果
            if(tmp==target)
            {
                ret=max(ret,right-left+1);
            }
            right++;
        }
        if(ret==-1)return ret;
        else return nums.size()-ret;
    }
};
相关推荐
Tisfy1 分钟前
LeetCode 1351.统计有序矩阵中的负数:O(m+n)时间复杂度——抽象题解
算法·leetcode·矩阵·题解·遍历
doukaiyu4 分钟前
P3613 【深基15.例2】寄包柜
算法
CoderCodingNo14 分钟前
【GESP】C++五级真题(数论-素数思想考点) luogu-P10720 [GESP202406 五级] 小杨的幸运数字
开发语言·c++·算法
小李小李快乐不已16 分钟前
算法技巧理论基础
数据结构·c++·算法·leetcode·hot100
少许极端21 分钟前
算法奇妙屋(二十一)-两个数组或字符串的dp问题(动态规划)
算法·动态规划·两个数组或字符串的dp问题
草莓熊Lotso21 分钟前
《算法闯关指南:递归,搜索与回溯算法--递归》--04. 两两交换链表中的结点 ,05.Pow(x,n)
数据结构·算法·链表
Bruce_kaizy24 分钟前
c++图论——最短路之Johnson算法
开发语言·数据结构·c++·算法·图论
蒙奇D索大34 分钟前
【数据结构】排序算法精讲 | 交换排序全解:交换思想、效率对比与实战代码剖析
数据结构·笔记·考研·算法·排序算法·改行学it
sin_hielo36 分钟前
leetcode 1351
数据结构·算法·leetcode
睡醒了叭38 分钟前
图像分割-传统算法-边缘分割
图像处理·opencv·算法·计算机视觉