1658.将x减到0的最小操作数

题目

链接:leetcode链接
在这里插入图片描述

思路分析(滑动窗口)

题目要求从最左边或者最右边移除元素,需要思考两侧,这是比较麻烦的。
正难则反,我们逆向思维一下,最后剩余的元素是不是中间的连续区间,所以,这个题目可以转化成寻找一个最长连续子数组,使得子数组的和为原数组的和减去x。

很明显,使用滑动窗口可以很快速的解决这道题。

但是这道题目还是有一些细节需要考虑的:
1、可能原数组的和 <= x,这是要进行特殊判断的
2、确定好如何进窗口,判断,出窗口,更新结果。
3、最后的返回值,要用size - len,别直接返回len

代码

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;//可能总和小于x
        if(target == 0) return nums.size();

        int len = 0,s = 0;
        for(int left = 0,right = 0;right < nums.size();++right)
        { 
            s += nums[right];//进窗口
            while(s > target)//出窗口
            {
                s -= nums[left];
                ++left;
            }

            if(s == target)
                len = max(right - left + 1,len);
            
        }

        return len == 0?-1:nums.size() - len;
        
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值