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

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

题目

题目解析及思路

题目要求每次操作删除最左或最右的元素 ,并从x中减去,返回当x = 0 时的最小操作数

  • 正难则反:求值为sum - x的区间

代码

cpp 复制代码
class Solution {
public:
    int minOperations(vector<int>& nums, int x) {
        int res=1e5+10,n = nums.size();
        int sum = accumulate(nums.begin(),nums.end(),0);
        int ans = 0;
        int k = sum - x;
        if(k <0) return -1;
        for(int i=0,j=0;i<n;i++)
        {
            ans += nums[i];
            while(ans > k) ans -= nums[j++];
            if(ans == k) res = min(res,n- (i-j+1));
        }
        if(res == 1e5 + 10) res = -1;
        return res;
    }
};
相关推荐
一起养小猫1 分钟前
Flutter for OpenHarmony 进阶:推箱子游戏算法与关卡设计深度解析
算法·flutter·游戏
XH华1 分钟前
备战蓝桥杯,第八章:位运算符和操作符属性
职场和发展·蓝桥杯
民乐团扒谱机2 分钟前
【微实验】Zhang-Suen 快速并行细化算法与MATLAB实现
人工智能·学习·算法·计算机视觉·数学建模·matlab
iAkuya5 分钟前
(leetcode)力扣100 60单词搜索(回溯)
算法·leetcode·职场和发展
卖报的大地主6 分钟前
强化学习在图像生成中的应用:范式演进、算法机制与前沿展望
算法
圣保罗的大教堂9 分钟前
leetcode 3637. 三段式数组 I 简单
leetcode
ʚB҉L҉A҉C҉K҉.҉基҉德҉^҉大10 分钟前
C++中的策略模式进阶
开发语言·c++·算法
June bug13 分钟前
【PMP】项目生命周期与组织变革
职场和发展·学习方法
June bug21 分钟前
【PMP】风险管理
经验分享·职场和发展·学习方法
weixin_4454023026 分钟前
模板元编程应用场景
开发语言·c++·算法