【C++习题】12.滑动窗口_将 x 减到 0 的最小操作数

文章目录

--

题目链接:

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


题目描述:


解法

正难则反

转化为:找出最长的子数组的长度len,所有的元素的和刚好等于sum-x

  1. left=0,right=0

  2. 进窗口,sum±nums[right]

  3. 判断,sum>target

    出窗口,sum-=nums[left]

  4. 更新结果,sum==target

这里需要注意的是,若当right指向c的时候>target,即right指向c-1的时候<target

此时left往后移动一位,right就不需要从头开始遍历了,因为left指向1的时候,right1~c-1b之间的距离都是<target的。


C++ 算法代码:

cpp 复制代码
class Solution 
{
    public:
    int minOperations(vector<int>& nums, int x) 
    {
        int sum = 0;// 计算数组中所有元素的总和
        for(int a : nums) sum += a;
        int target = sum - x;// 计算目标值,即总和减去x
        // 细节问题
        if(target < 0) return -1;// 如果目标值小于0,说明无论如何操作都无法达到目标,返回-1
        int ret = -1;// 初始化结果为-1,表示尚未找到有效解
        // 使用滑动窗口技术来寻找最长的子数组,其和等于target
        for(int left = 0, right = 0, tmp = 0; right < nums.size(); right++)
        {
            tmp += nums[right]; // 进窗口// 将当前元素加入临时和
            while(tmp > target) // 判断
                tmp -= nums[left++]; // 出窗口// 如果临时和大于目标值,则移动左指针以减少临时和
            if(tmp == target) // 更新结果// 如果临时和等于目标值,则更新结果
                ret = max(ret, right - left + 1);
        }
        if(ret == -1) return ret;// 如果没有找到有效的子数组,返回-1
        else return nums.size() - ret;// 否则,返回需要移除的元素数量,即数组长度减去最长子数组的长度
    }
};

图解

输入:nums = [1,1,4,2,3], x = 5

  1. sum=1+1+4+2+3=11

    target=sum-x=11-5=6

    left = 0, right = 0, tmp = 0

    循环两次后

    tmp == target

    ret = max(ret, right - left + 1)=3

  2. right++,

    tmp > target

    tmp -= nums[left++];

    tmp -= nums[left++];

  3. tmp == target

    ret = max(ret, right - left + 1)=3

    后面步骤差不多,不过多赘述了。

  4. return nums.size() - ret=5

相关推荐
qq_310658512 分钟前
webrtc代码走读(五)-QOS-FEC原理
网络·c++·webrtc
前端世界13 分钟前
当网络里混入“假网关”:用 Scapy 写一个 DHCP 欺骗检测器(附完整代码与讲解)
开发语言·网络·php
千里镜宵烛14 分钟前
Lua-编译,执行和错误
开发语言·lua
赵谨言25 分钟前
基于python二手车价值评估系统的设计与实现
大数据·开发语言·经验分享·python
Want59526 分钟前
C/C++动态爱心
c++
ysa05103028 分钟前
利用数的变形简化大规模问题#数论
c++·笔记·算法
DARLING Zero two♡1 小时前
【优选算法】D&C-Mergesort-Harmonies:分治-归并的算法之谐
java·数据结构·c++·算法·leetcode
java1234_小锋1 小时前
PyTorch2 Python深度学习 - 初识PyTorch2,实现一个简单的线性神经网络
开发语言·python·深度学习·pytorch2
胡萝卜3.01 小时前
C++面向对象继承全面解析:不能被继承的类、多继承、菱形虚拟继承与设计模式实践
开发语言·c++·人工智能·stl·继承·菱形继承·组合vs继承
蜗牛沐雨1 小时前
解决 OpenSSL 3.6.0 在 macOS 上 Conan 构建失败的链接错误
c++·macos