1.题目

2.算法思路
这个题目难在要转化一下才能用滑动窗口。
题意是需要在数组的前后两段区间进行解题,但同时对两段区间进行操作是比较困难的,我们可以将中间这段区间只和与nums_sum-x(数组总和-x)进行比较,这样就可以很好的将两段区间合并成一段区间,进而使用滑动窗口算法解题。
滑动窗口算法我在《优选基础算法》中滑动窗口的前两个题目中介绍的比较清楚,大家可以去看一看。
3.提交结果与代码实现

class Solution {
public:
    int minOperations(vector<int>& nums, int x) {
        int sum1=0,n=nums.size(),sum2=0,len=0;
        for(auto e:nums) sum1+=e;
        int target=sum1-x;//正难则反
        if(target<0) return -1;//考虑边界情况
        if(target==0) return n;//考虑边界情况
        for(int left=-1,right=0;right<n;right++){
            sum2+=nums[right];//进窗口
            while(sum2>target) sum2-=nums[++left];出窗口
            if(sum2==target) len=max(len,right-left);//更新结果
        }
        if(len==0) return -1;
        else return nums.size()-len;
    }
};时间复杂度:O(n)。空间复杂度:O(1)。



















