两个无重叠子数组的最大和

1031. 两个无重叠子数组的最大和 - 力扣(LeetCode)

Solution

这题思路和 2555. 两个线段获得的最多奖品 - 力扣(LeetCode) 基本上一模一样,利用dp的思想先维护一个数组dp,dp[i]表示索引[0...i]范围内符合要求的子数组最大值,然后第二次遍历,维护当前窗口值,再加上这个窗口之前的dp[l-1],选出最大值即可。

需要注意的是这题需要这样做两边,左边first个右边second个,左边second和右边first个,选出其中的最大值即为答案。

cpp 复制代码
class Solution {
public:
    int maxSumTwoNoOverlap(vector<int>& nums, int firstLen, int secondLen) {
        int n = nums.size();
        vector<int> dp(n + 1, 0);
        int l = 0, win = 0;
        for (int r = 0; r < n; ++r) {
            win += nums[r];
            while (r - l + 1 > firstLen) {
                win -= nums[l];
                l++;
            }
            dp[r] = (r > 0) ? max(dp[r - 1], win) : win;
        }
        // for(int i=0;i<n;++i)
        //     cout<<dp[i]<<" ";
        l = 0, win = 0;
        int res = 0;
        for (int r = 0; r < n; ++r) {
            win += nums[r];
            while (r - l + 1 > secondLen) {
                win -= nums[l];
                l++;
            }
            if (l > 0)
                res = max(res, win + dp[l - 1]);
        }

        l=0,win=0;
        for (int r = 0; r < n; ++r) {
            win += nums[r];
            while (r - l + 1 > secondLen) {
                win -= nums[l];
                l++;
            }
            dp[r] = (r > 0) ? max(dp[r - 1], win) : win;
        }

        l = 0, win = 0;
        for (int r = 0; r < n; ++r) {
            win += nums[r];
            while (r - l + 1 > firstLen) {
                win -= nums[l];
                l++;
            }
            if (l > 0)
                res = max(res, win + dp[l - 1]);
        }

        return res;
    }
};
相关推荐
bbbb3658 小时前
算法工程中的可扩展性与分布式实现方案的技术7
算法
Shining05968 小时前
AI 编译器系列(六)《Stable Diffusion 在 InfiniTensor 推理框架中的适配与工程实践》
人工智能·算法·stable diffusion·大模型·图像生成·ai编译器·infinitensor
佩奇大王8 小时前
P159 摆动序列
java·开发语言·算法
weixin_537590458 小时前
《C程序设计语言》练习答案(练习1-7)
linux·c语言·算法
!停8 小时前
C++基础入门(缺省参数,函数重载,引用)
开发语言·c++·算法
我不是秋秋8 小时前
软件开发项目各角色关系解析:产品/前后端/测试如何高效协作?
java·算法·面试·职场和发展·哈希算法
Tisfy8 小时前
LeetCode 1886.判断矩阵经轮转后是否一致:模拟
算法·leetcode·矩阵·题解·模拟
dapeng287010 小时前
分布式系统容错设计
开发语言·c++·算法
qq_4176950510 小时前
代码热修复技术
开发语言·c++·算法
C++ 老炮儿的技术栈16 小时前
volatile使用场景
linux·服务器·c语言·开发语言·c++