【动态规划-最大子段和】力扣1191. K 次串联后最大子数组之和

给定一个整数数组 arr 和一个整数 k ,通过重复 k 次来修改数组。

例如,如果 arr = [1, 2] , k = 3 ,那么修改后的数组将是 [1, 2, 1, 2, 1, 2] 。

返回修改后的数组中的最大的子数组之和。注意,子数组长度可以是 0,在这种情况下它的总和也是 0。

由于 结果可能会很大,需要返回的 109 + 7 的 模 。

示例 1:

输入:arr = [1,2], k = 3

输出:9

示例 2:

输入:arr = [1,-2,1], k = 5

输出:2

示例 3:

输入:arr = [-1,-2], k = 7

输出:0

cpp 复制代码
class Solution {
public:
    int kConcatenationMaxSum(vector<int>& arr, int k) {
        int MOD = 1e9 + 7;
        long long sum = 0;
        long long maxAns = 0;
        long long pre = 0, maxMid = 0;
        for(int &num : arr){
            sum += num;
            maxAns = max(maxAns, sum);
            pre = max(pre + num, (long long)num);
            maxMid = max(maxMid, pre);
        }

        if(k == 1){
            return maxMid % MOD;
        }

        //最大后缀和
        long long maxAns2 = 0;
        long long sum2 = 0;
        for(int i = arr.size() - 1; i >= 0 ; i--){
            sum2 += arr[i];
            maxAns2 = max(maxAns2, sum2);
        }

        int theMax;
        if(sum > 0){
                theMax = max((k-2) * sum + maxAns + maxAns2, maxMid)%MOD;
        }
        else if(sum <= 0){
                theMax = max(maxMid,maxAns + maxAns2)%MOD;
        }
        return theMax;
    }
};

本题没有官解,也没有看到统一的比较好的题解。这道题主要是要考虑各种情况,可以先列出所有的情况,最后再进行代码优化,将类似的情况整理在一起。maxMid是最大子段和,使用的是Kadane算法,maxAns是最大前缀和,maxAns2是最大后缀和。首先如果当k为1的时候,最大子段和就是maxMid。接下来讨论sum的情况,如果sum>0,就要比较两种情况,一种是复制的2到k-1组元素的和加上第一组元素的最大后缀和再加上最后一组元素的最大前缀和,第二种情况是第一组元素中的最大子段和就是整个复制过的数组的最大子段和。当sum<=0的时候,也要比较两种情况哪个大,第一种是第一组元素中的最大子段和,第二种是最大前缀和加上最大后缀和(例如第一组元素的最大后缀和加上第二组元素的最大前缀和)。

相关推荐
LeetCode天天刷5 分钟前
【软件认证】比特翻转【滑动窗口】
算法
源代码•宸7 分钟前
Leetcode—1123. 最深叶节点的最近公共祖先【中等】
经验分享·算法·leetcode·职场和发展·golang·dfs
s砚山s10 分钟前
代码随想录刷题——二叉树篇(十三)
数据结构·算法
alphaTao14 分钟前
LeetCode 每日一题 2026/1/5-2026/1/11
算法·leetcode
山上三树15 分钟前
详细介绍 C 语言中的 #define 宏定义
c语言·开发语言·算法
黎雁·泠崖30 分钟前
二叉树知识体系全梳理:从基础到进阶一站式通关
c语言·数据结构·leetcode
AI科技星31 分钟前
引力与电磁的动力学耦合:变化磁场产生引力场与电场方程的第一性原理推导、验证与统一性意义
服务器·人工智能·科技·线性代数·算法·机器学习·生活
蜕变菜鸟33 分钟前
JS的Object.keys()和sort()排序的用法
数据结构·算法
源代码•宸34 分钟前
Golang基础语法(go语言error、go语言defer、go语言异常捕获、依赖管理、Go Modules命令)
开发语言·数据库·后端·算法·golang·defer·recover
如果你想拥有什么先让自己配得上拥有44 分钟前
算数顺序的逻辑和发展?
算法