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

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;
    }
};
相关推荐
智者知已应修善业17 分钟前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn19 分钟前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室1 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星1 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
云泽8082 小时前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++
科研前沿2 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨2 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
AI进化营-智能译站2 小时前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
晨曦夜月3 小时前
map与unordered_map区别
算法·哈希算法
Morwit3 小时前
QML组件之间的通信方案(暴露子组件)
c++·qt·职场和发展