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

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;
    }
};
相关推荐
Snow_day.18 小时前
有关排列排列组合(1)
数据结构·算法·贪心算法·动态规划·图论
Ccjf酷儿18 小时前
C++语言程序设计 (郑莉)第六章 数组、指针和字符串
开发语言·c++
陌路2018 小时前
C++28 STL容器--array
开发语言·c++
dora18 小时前
【开发火星地平线辅助】智商不够,编程来凑
算法
im_AMBER18 小时前
Leetcode 100 在链表中插入最大公约数
数据结构·c++·笔记·学习·算法·leetcode·链表
Z1Jxxx18 小时前
删除字符串2
开发语言·c++·算法
踩坑记录18 小时前
leetcode hot100 15. 三数之和 medium
算法·leetcode·职场和发展
你的冰西瓜18 小时前
C++中的set容器详解
开发语言·c++·stl
独自破碎E18 小时前
【二分法】旋转数组的最小数字
数据结构·算法·排序算法
苦藤新鸡18 小时前
9.找到字符串中所有字母异位词
数据结构·c++·算法·力扣