【算法专题突破】滑动窗口- 将 x 减到 0 的最小操作数(12)

目录

[1. 题目解析](#1. 题目解析)

[2. 算法原理](#2. 算法原理)

[3. 代码编写](#3. 代码编写)

写在最后:


1. 题目解析

题目链接:1658. 将 x 减到 0 的最小操作数 - 力扣(Leetcode)

这道题并不难理解,其实就是在数组里找值,直到把x减成0,

这里要注意的是,题目要求移除的之能是数组最左边或者最右边的值,

然后返回最小的操作数即可。

如果直接从两边去找可能不太好解决,

我们可以把这个问题转化成:

找出最长的中间子数组,这样我们就能得到最小的操作数了。

2. 算法原理

这道题可以用滑动窗口来解决,

具体思路是这样的:

数组的总和 - x = target ,这个target值就是中间数组的值,

我们维护一个窗口,不断往窗口里面进值,

如果窗口总值 < target,就继续进窗口

如果 == target,那就记录操作次数,

如果 > target, 就出窗口。

来看代码:

3. 代码编写

cpp 复制代码
class Solution {
public:
    int minOperations(vector<int>& nums, int x) {
        int left = 0, right = 0, sum = 0, len = INT_MAX, target = -x;
        for(auto e : nums) target += e;
        if(target < 0) return -1;
        int n = nums.size();
        while(right < n) {
            sum += nums[right++];
            while(left < n && sum > target) sum -= nums[left++];
            if(sum == target) len = min(len, n - (right - left));
        }
        return len == INT_MAX ? -1 : len;
    }
};

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果感到有所收获的话可以给博主点一个哦。

如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~

相关推荐
小雨下雨的雨1 分钟前
数独算法与求解器鸿蒙PC Electron框架完成深度解析
javascript·人工智能·算法·游戏·华为·electron·鸿蒙系统
YangYang9YangYan2 分钟前
学数据分析对学习编程的价值
学习·数据挖掘·数据分析
HZ·湘怡4 分钟前
数据结构之排序算法 (1)--插入排序
c语言·数据结构·算法·排序算法
ouliten4 分钟前
[Triton笔记7]融合注意力 (Fused Attention)
人工智能·笔记·算法
开源Z5 分钟前
LeetCode 238 · 除自身以外数组的乘积:左右两遍扫描,不用除法
算法·leetcode
踏着七彩祥云的小丑6 分钟前
Go学习第3天:变量+常量+运算符
开发语言·学习·golang·go
sensen_kiss12 分钟前
CPT304 SoftwareEngineeringII 软件工程 2 Pt.6 批判性分析 / 关键性分析(Critical Analysis)
学习·软件工程
雪落漂泊12 分钟前
C++ 继承与多态(下)
开发语言·c++
写代码的白开水13 分钟前
从 RAG 到 LLM Wiki:团队知识库工程化的一点学习
学习
charlie11451419114 分钟前
通用GUI编程技术——图形渲染实战(四十九)——完全自绘控件架构:状态机与动画
c++·windows·架构·图形渲染