力扣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;
    }
};
相关推荐
s1hiyu几秒前
实时控制系统验证
开发语言·c++·算法
daad7777 分钟前
V4L2_mipi-csi
算法
2301_7657031411 分钟前
C++代码复杂度控制
开发语言·c++·算法
m0_7088309621 分钟前
C++中的享元模式实战
开发语言·c++·算法
naruto_lnq28 分钟前
分布式计算C++库
开发语言·c++·算法
m0_706653231 小时前
模板编译期排序算法
开发语言·c++·算法
历程里程碑1 小时前
Linxu14 进程一
linux·c语言·开发语言·数据结构·c++·笔记·算法
木井巳1 小时前
【递归算法】验证二叉搜索树
java·算法·leetcode·深度优先·剪枝
m0_561359671 小时前
嵌入式C++加密库
开发语言·c++·算法
近津薪荼1 小时前
优选算法——双指针专题7(单调性)
c++·学习·算法