欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 明星 > 1658.将x减到0的最小操作数

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

2024/10/24 19:17:12 来源:https://blog.csdn.net/2303_78940834/article/details/142031996  浏览:    关键词: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;//可能总和小于xif(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;}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com