滑动窗口实例4(将x减到0的最小操作数)

题目:

给你一个整数数组 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

算法原理:

正面入手解题,情况繁杂,一会是取左边一会是取右边,但是正难则反,反面入手解题:

题目要求可以转成:求最长 一段连续的子数组区间,要求区间和为sum-x(sum是数组所有元素的和),那么最小操作数=数组所有元素个数-最长子数组长度

题目本来的要求是:求「左端+右端」两段连续的、和为 x 的最短数组

连续区间,可以考虑用滑动窗口来解题

1 求出数组所有元素的和sum 目标值target=sum-x

2 用滑动窗口,找出最长的子数组,使其和为target

细节:target可能为负数(当sum<x时)但是题目提示中所有元素均不存在负数

所以返回-1

left=0(左边界) right=0(指向待进入窗口的元素) sum2统计区间和

a 进窗口:sum2+=nums[right]

b 判断: 若是sum2>target 循环出窗口,直至sum<=target

若是循环结束后,sum2==target,则找到一组结果,若此次结果更优则更新结果

c 出窗口:sum-=nums[left],left++

代码实现:

cpp 复制代码
class Solution 
{
public:
    int minOperations(vector<int>& nums, int x)
    {
        int sum = 0;
        for(auto e:nums)
        {
            sum+=e;
        }

        int target = sum-x;
        if(target<0)//细节
        {
            return -1;
        }

        int left = 0;
        int right = 0;
        int n = nums.size();
        int sum2 = 0;
        int ret = -1;
        while(right<n)
        {
            sum2+=nums[right];//进窗口
            while(sum2>target)//判断
            {
                sum2-=nums[left++];//出窗口
            }

            if(sum2==target)//更新结果
            {
                ret = max(ret,right-left+1);
            }
            right++;
        }
        return ret==-1?ret: n-ret;
    }
};
相关推荐
追随者永远是胜利者2 小时前
(LeetCode-Hot100)20. 有效的括号
java·算法·leetcode·职场和发展·go
瓦特what?3 小时前
快 速 排 序
数据结构·算法·排序算法
niuniudengdeng3 小时前
基于时序上下文编码的端到端无文本依赖语音分词模型
人工智能·数学·算法·概率论
hetao17338373 小时前
2026-02-13~16 hetao1733837 的刷题记录
c++·算法
你的冰西瓜5 小时前
2026春晚魔术揭秘——变魔法为物理
算法
忘梓.5 小时前
解锁动态规划的奥秘:从零到精通的创新思维解析(10)
c++·算法·动态规划·代理模式
foolish..5 小时前
动态规划笔记
笔记·算法·动态规划
消失的dk5 小时前
算法---动态规划
算法·动态规划
羑悻的小杀马特5 小时前
【动态规划篇】欣赏概率论与镜像法融合下,别出心裁探索解答括号序列问题
c++·算法·蓝桥杯·动态规划·镜像·洛谷·空隙法
绍兴贝贝5 小时前
代码随想录算法训练营第四十六天|LC647.回文子串|LC516.最长回文子序列|动态规划总结
数据结构·人工智能·python·算法·动态规划·力扣