力扣 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
相关推荐
sali-tec6 小时前
C# 基于halcon的视觉工作流-章66 四目匹配
开发语言·人工智能·数码相机·算法·计算机视觉·c#
小明说Java6 小时前
常见排序算法的实现
数据结构·算法·排序算法
行云流水20197 小时前
编程竞赛算法选择:理解时间复杂度提升解题效率
算法
smj2302_796826529 小时前
解决leetcode第3768题.固定长度子数组中的最小逆序对数目
python·算法·leetcode
cynicme9 小时前
力扣3531——统计被覆盖的建筑
算法·leetcode
core5129 小时前
深度解析DeepSeek-R1中GRPO强化学习算法
人工智能·算法·机器学习·deepseek·grpo
mit6.82410 小时前
计数if|
算法
a伊雪10 小时前
c++ 引用参数
c++·算法
圣保罗的大教堂10 小时前
leetcode 3531. 统计被覆盖的建筑 中等
leetcode