力扣 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
相关推荐
小白菜又菜2 分钟前
Leetcode 1925. Count Square Sum Triples
算法·leetcode
登山人在路上1 小时前
Nginx三种会话保持算法对比
算法·哈希算法·散列表
写代码的小球1 小时前
C++计算器(学生版)
c++·算法
AI科技星1 小时前
张祥前统一场论宇宙大统一方程的求导验证
服务器·人工智能·科技·线性代数·算法·生活
Fuly10242 小时前
大模型剪枝(Pruning)技术简介
算法·机器学习·剪枝
Xの哲學2 小时前
Linux网卡注册流程深度解析: 从硬件探测到网络栈
linux·服务器·网络·算法·边缘计算
bubiyoushang8882 小时前
二维地质模型的表面重力值和重力异常计算
算法
仙俊红3 小时前
LeetCode322零钱兑换
算法
颖风船3 小时前
锂电池SOC估计的一种算法(改进无迹卡尔曼滤波)
python·算法·信号处理
551只玄猫3 小时前
KNN算法基础 机器学习基础1 python人工智能
人工智能·python·算法·机器学习·机器学习算法·knn·knn算法