滑动窗口练习4-将x减到0的最小操作数

题目链接:* *. - 力扣(LeetCode)**(字节跳动)

题目描述:

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

提示:正难则反

解法(滑动窗口):

算法思路:

题目要求的是数组「左端 + 右端」两段连续的,和为 x 的最短数组,信息量稍微多一些,不易理清思路;我们可以转化成求数组内一段连续的、和为 sum(nums) - x的最长数组。此时,就是熟悉的「滑动窗口」问题了。

算法流程:

a.转化问题:求 target = all - x 的 最长数组。如果targe < 0,问题无解;
b.初始化左右指针 left = 0,right = 0(滑动窗口区间表示为[left,right),左右区间是否开闭很重要,必须设定与代码一致),记录当前滑动窗口内数组和的变量 sum = 0,记录当前满足条件数组的最大区间长度 maxlen = 0;
c.当 right 小于等于数组长度时,一直循环:
1️⃣ 如果 sum < target ,右移右指针,直至变量和大于等于 target,或右指针已经移到头
2️⃣ 如果 sum > target ,右移左指针,直至变量和小于等于 target,或左指针已经移到头
3️⃣ 如果经过前两步的左右移动使得 sum == target,维护满足条件数组的最大长度,并让下个元素进入窗口
d.循环结束后,如果 ret 的值有意义,则计算结果返回;否则,返回 -1。

cpp 复制代码
class Solution {
public:
    int minOperations(vector<int>& nums, int x) {
        int n  = nums.size();
        int sum = 0;
        int maxlen = 0;
        int all = 0;
        for(int i = 0; i < n; i++){
            all += nums[i];
        }

        int target = all - x;//最长子数组目标值
        //处理细节
        if(target < 0) return -1;
        if(target == 0) return n;

        for(int left = 0, right = 0; right < n; right++){
            //进窗口
            sum += nums[right];
            while(sum > target){//判断
                sum -= nums[left++];//出窗口
            }
            //更新结果
            if(sum == target){
                maxlen = max(right - left + 1, maxlen);
            }
        }

        int ret = n - maxlen == n ? -1 :n - maxlen;
        return ret;
    }
};
相关推荐
zl_vslam16 分钟前
SLAM中的非线性优-3D图优化之绝对位姿SE3约束右扰动(十七)
人工智能·算法·计算机视觉·3d
Cestb0n21 分钟前
某果app 加密校验算法逆向分析
python·算法·逆向安全
机器学习之心34 分钟前
MATLAB基于近红外光谱检测的菠萝含水率预测(多种预处理+PLS)
人工智能·算法·matlab·近红外光谱检测
程序员-King.1 小时前
day166—递归—多边形三角剖分的最低得分(LeetCode-1039)
算法·leetcode·深度优先·动态规划·递归
夏鹏今天学习了吗1 小时前
【LeetCode热题100(94/100)】下一个排列
算法·leetcode·职场和发展
AI科技星1 小时前
光的几何起源:从螺旋时空到量子现象的完全统一
开发语言·人工智能·线性代数·算法·机器学习
q_35488851531 小时前
机器学习:Python地铁人流量数据分析与预测系统 基于python地铁数据分析系统+可视化 时间序列预测算法 ✅
大数据·人工智能·python·算法·机器学习·信息可视化·数据分析
永远都不秃头的程序员(互关)2 小时前
【K-Means深度探索(十二)】K-Means项目实战:从数据到决策的完整工作流!
算法·机器学习·kmeans
散峰而望2 小时前
【基础算法】高精度运算深度解析与优化
数据结构·c++·算法·链表·贪心算法·推荐算法
一起养小猫2 小时前
LeetCode100天Day16-跳跃游戏II与H指数
算法·游戏