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

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

Solution

这题思路和 2555. 两个线段获得的最多奖品 - 力扣(LeetCode) 基本上一模一样,利用dp的思想先维护一个数组dp,dpi表示索引0...i范围内符合要求的子数组最大值,然后第二次遍历,维护当前窗口值,再加上这个窗口之前的dpl-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;
    }
};
相关推荐
无限码力20 分钟前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly28 分钟前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1231 小时前
SolidWorks草图转三维DWG技巧
算法
凡人叶枫1 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
不想写代码的星星1 小时前
std::move 根本不移动,就像老婆饼里没有老婆
c++
redaijufeng1 小时前
C++雾中风景7:闭包
c++·算法·风景
小欣加油2 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
思麟呀2 小时前
C++11 核心特性(三):强类型枚举、static_assert 与 std::tuple
开发语言·c++
一拳一个呆瓜2 小时前
【STL】C++程序的启动与终止
c++·stl
尽兴-2 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度