LeetCode //C - 1031. Maximum Sum of Two Non-Overlapping Subarrays

1031. Maximum Sum of Two Non-Overlapping Subarrays

Given an integer array nums and two integers firstLen and secondLen, return the maximum sum of elements in two non-overlapping subarrays with lengths firstLen and secondLen.

The array with length firstLen could occur before or after the array with length secondLen, but they have to be non-overlapping.

A subarray is a contiguous part of an array.

Example 1:

Input: nums = 0,6,5,2,2,5,1,9,4, firstLen = 1, secondLen = 2
Output: 20
Explanation: One choice of subarrays is 9 with length 1, and 6,5 with length 2.

Example 2:

Input: nums = 3,8,1,3,2,1,8,9,0, firstLen = 3, secondLen = 2
Output: 29
Explanation: One choice of subarrays is 3,8,1 with length 3, and 8,9 with length 2.

Example 3:

Input: nums = 2,1,5,6,0,9,5,0,3,8, firstLen = 4, secondLen = 3
Output: 31
Explanation: One choice of subarrays is 5,6,0,9 with length 4, and 0,3,8 with length 3.

Constraints:
  • 1 <= firstLen, secondLen <= 1000
  • 2 <= firstLen + secondLen <= 1000
  • firstLen + secondLen <= nums.length <= 1000
  • 0 <= numsi <= 1000

From: LeetCode

Link: 1031. Maximum Sum of Two Non-Overlapping Subarrays


Solution:

Ideas:
  • Try both orders:
    • firstLen subarray before secondLen
    • secondLen subarray before firstLen
  • While scanning, keep:
    • the best sum of the left subarray seen so far
    • combine it with the current right subarray
Code:
c 复制代码
int maxSumTwoNoOverlap(int* nums, int numsSize, int firstLen, int secondLen) {
    int prefix[1001] = {0};
    int i;
    
    for (i = 0; i < numsSize; i++) {
        prefix[i + 1] = prefix[i] + nums[i];
    }
    
    int ans = 0;
    
    /* Case 1: firstLen subarray is before secondLen subarray */
    int bestFirst = prefix[firstLen] - prefix[0];
    for (i = firstLen + secondLen; i <= numsSize; i++) {
        int firstSum = prefix[i - secondLen] - prefix[i - secondLen - firstLen];
        if (firstSum > bestFirst) {
            bestFirst = firstSum;
        }
        
        int secondSum = prefix[i] - prefix[i - secondLen];
        int total = bestFirst + secondSum;
        if (total > ans) {
            ans = total;
        }
    }
    
    /* Case 2: secondLen subarray is before firstLen subarray */
    int bestSecond = prefix[secondLen] - prefix[0];
    for (i = firstLen + secondLen; i <= numsSize; i++) {
        int secondSum = prefix[i - firstLen] - prefix[i - firstLen - secondLen];
        if (secondSum > bestSecond) {
            bestSecond = secondSum;
        }
        
        int firstSum = prefix[i] - prefix[i - firstLen];
        int total = bestSecond + firstSum;
        if (total > ans) {
            ans = total;
        }
    }
    
    return ans;
}
相关推荐
dtq04243 分钟前
C语言刷题函数1-判断素数(分支语句,函数两种方法)
c语言·开发语言·学习
Tairitsu_H6 分钟前
[LC优选算法#4] 滑动窗口 | 串联所有单词的⼦串 | 最⼩覆盖⼦串
c++·算法·滑动窗口
devilnumber8 分钟前
Java 二分查找(二分算法)详解 + 实战运用 + 核心坑点
java·开发语言·算法
洛水水10 分钟前
【力扣100题】84.字符串解码
算法·leetcode·职场和发展
AI科技星19 分钟前
第四卷:橡皮泥江湖(拓扑学)
c语言·开发语言·网络·量子计算·agi·拓扑学
2601_9516438819 分钟前
关于C语言中getchar()的详细使用
c语言·输入输出·getchar()·eof·文件结束符
小七在进步23 分钟前
数据结构:线性表之单链表
c语言·数据结构
MicroTech202537 分钟前
量子隐形传态路线的瓶颈与突破,微算法科技(MLGO)以技术创新助力量子通信长距离组网
科技·算法·量子计算
洛水水37 分钟前
【力扣100题】89.下一个排列
数据结构·算法·leetcode
洛水水38 分钟前
【力扣100题】90.寻找重复数
算法·leetcode·职场和发展