力扣 1425带限制的子序列和

这是一道 动态规划加单调队列的题,重点加强单调队列知识的学习

回归本题,这个题中,动态规划的部分略去,状态转移方程可求

单调队列部分

1维护队头 if(i-sta.front() == k) sta.pop_front();

2维护队尾

while(!sta.empty() &&dp[sta.back()] <dp[i]) sta.pop_back();

sta.push_back(i);

3计算过程,动态规划

dp[i] = max(dp[sta.front()]+nums[i],nums[i]);

ans = max(ans,dp[i]);

复制代码
/*
 * @lc app=leetcode.cn id=1425 lang=cpp
 *
 * [1425] 带限制的子序列和
 */

// @lc code=start
class Solution {
public:
    int constrainedSubsetSum(vector<int>& nums, int k) {
        vector<int> dp(nums.size(),0);
        dp[0] = nums[0];
        int ans = dp[0];
        deque<int> sta;
        sta.push_back(0);
        for(int i = 1;i<nums.size();i++)
        {
            dp[i] = max(dp[sta.front()]+nums[i],nums[i]);
            ans = max(ans,dp[i]);
            if(i-sta.front() == k) sta.pop_front();
            while(!sta.empty() &&dp[sta.back()] <dp[i]) sta.pop_back();
            sta.push_back(i);
        }
        return ans;
    }
};
// @lc code=end
相关推荐
LYFlied1 天前
【每日算法】LeetCode 153. 寻找旋转排序数组中的最小值
数据结构·算法·leetcode·面试·职场和发展
唐装鼠1 天前
rust自动调用Deref(deepseek)
开发语言·算法·rust
ytttr8731 天前
MATLAB基于LDA的人脸识别算法实现(ORL数据库)
数据库·算法·matlab
jianfeng_zhu1 天前
整数数组匹配
数据结构·c++·算法
smj2302_796826521 天前
解决leetcode第3782题交替删除操作后最后剩下的整数
python·算法·leetcode
LYFlied1 天前
【每日算法】LeetCode 136. 只出现一次的数字
前端·算法·leetcode·面试·职场和发展
唯唯qwe-1 天前
Day23:动态规划 | 爬楼梯,不同路径,拆分
算法·leetcode·动态规划
做科研的周师兄1 天前
中国土壤有机质数据集
人工智能·算法·机器学习·分类·数据挖掘
来深圳1 天前
leetcode 739. 每日温度
java·算法·leetcode
LYFlied1 天前
WebAssembly (Wasm) 跨端方案深度解析
前端·职场和发展·wasm·跨端