首页 > 其他分享 >动态规划2:计算最大连续子序列和

动态规划2:计算最大连续子序列和

时间:2024-07-21 11:55:25浏览次数:13  
标签:tmp arr int memo startIndex 序列 动态 规划 sum


import java.util.HashMap;
import java.util.Map;

public class DynamicProgramming2 {
    public static void main(String[] args) {
        int[] arr = {3,-4,2,-1,2,6,-5,4};
        //暴力枚举法
        System.out.println(getMaxSumSubArr(arr));
        //加上记忆Map
        System.out.println(getMaxSumSubArr2(arr));
        //从后往前,不用递归
        System.out.println(getMaxSumSubArr3(arr));
    }

    /**
     * 求其中和最大的连续子序列
     * 暴力枚举法
     * @param arr
     * @return
     */
    public static int getMaxSumSubArr(int[] arr){
        int sum = arr[0];
        for (int i = 0; i < arr.length; i++) {
            //每轮循环算出从index=i开头的和最大的子序列
            int tmp = getMaxSumSubArrGivingStartIndex(arr,i);
            sum = tmp>sum?tmp:sum;
        }
        return sum;
    }

    public static int getMaxSumSubArrGivingStartIndex(int[] arr, int startIndex) {
        if (startIndex == arr.length-1){
            //如果是最后一个序号,那肯定就是它自己了
            return arr[arr.length-1];
        }

        //子序列的最大和无非就是当前元素加上后续序列的和,但如果后续序列和小于0,那说明不加更大
        int maxSumSubArrGivingStartIndex = getMaxSumSubArrGivingStartIndex(arr, startIndex + 1);
        return arr[startIndex] + (maxSumSubArrGivingStartIndex >0?maxSumSubArrGivingStartIndex:0);
    }

    /**
     * 求其中和最大的连续子序列
     * 加上记忆Map
     * @param arr
     * @return
     */
    public static int getMaxSumSubArr2(int[] arr){

        Map<Integer,Integer> memo = new HashMap<>();

        int sum = arr[0];
        for (int i = 0; i < arr.length; i++) {
            //每轮循环算出从index=i开头的和最大的子序列
            //返回的结果中subArr[0]为最大和,subArr[1]为对应的子序列
            int tmp = getMaxSumSubArrGivingStartIndex(arr,i);
            sum = tmp>sum?tmp:sum;
        }
        return sum;
    }

    public static int getMaxSumSubArrGivingStartIndex2(int[] arr, int startIndex,Map<Integer,Integer> memo) {
        if (memo.get(startIndex) != null) {
            return memo.get(startIndex);
        }

        if (startIndex == arr.length-1){
            memo.put(startIndex,arr[arr.length-1]);
            return arr[arr.length-1];
        }

        int maxSumSubArrGivingStartIndex = getMaxSumSubArrGivingStartIndex(arr, startIndex + 1);
        int result = arr[startIndex] + (maxSumSubArrGivingStartIndex > 0 ? maxSumSubArrGivingStartIndex : 0);

        memo.put(startIndex,result);
        return result;
    }

    /**
     * 求其中和最大的连续子序列
     * 取消递归
     * @param arr
     * @return
     */
    public static int getMaxSumSubArr3(int[] arr){

        Map<Integer,Integer> memo = new HashMap<>();

        for (int i = arr.length-1; i >= 0 ; i--) {
            //从后往前,每轮循环算出从序号i开始的最大连续和
            if (i == arr.length-1){
                memo.put(i,arr[i]);
                continue; //注意这里是continue不是break
            }

            Integer tmp = memo.get(i + 1);
            int sum = tmp >0?arr[i]+tmp:arr[i];
            memo.put(i,sum);
        }

        int maxSum = memo.get(arr.length-1);
        for (int i = 0; i < arr.length; i++) {
            Integer tmp = memo.get(i);
            maxSum = tmp>maxSum?tmp:maxSum;
        }

        return maxSum;
    }
}

标签:tmp,arr,int,memo,startIndex,序列,动态,规划,sum
From: https://blog.csdn.net/m0_63246220/article/details/140585594

相关文章

  • 去趋势波动分析方法-捕捉时间序列数据在不同尺度上的变化特性
    前言近年来,降水过程中的分形行为和长期相关性成为了一个活跃的研究领域。这些研究表明,降水数据中存在分形行为,但分形理论在实际应用中仍然不够充分。传统方法的局限性:由于降水过程的非平稳性,传统的线性方法(如自相关函数分析或谱分析)在检测时间序列的这些属性时不可靠。非......
  • 基于python的非平稳时间序列模型
    前言平稳时间序列指的是宽平稳时间序列,就是指时间序列的均值、方差和协方差等一二阶矩存在但不随时间改变,表现为时间的常数。若三个条件有一个不成立,那么就称该序列为非平稳时间序列。包括确定性趋势时间序列和随机性趋势时间序列。要想把非平稳的时间序列转化为平稳的时......
  • 如何在Python中使用装饰器动态创建类方法?
    我正在开发一个Python项目,我需要在运行时动态地为类创建方法。我想使用装饰器根据一些外部配置将这些方法添加到类中。要求是:装饰器应该从外部配置(例如字典)读取方法定义。装饰器应该动态地将这些方法添加到类中。每个生成的方法都应具有配置中指定的自己唯一的实现。以......
  • python中时间序列数据的梯度计算
    我正在尝试编写一个函数,它可以从最适合下面的线返回梯度dataframe在浏览了谷歌的几个资源之后,我仍然不确定这是如何完成的。我明白最佳拟合线的计算公式为:y=mx+b将因变量(y)设置为foos,将自变量(x)设置为DateTimeDatafram......
  • Leetcode 中的动态规划
    对于初学者来说,Leetcode中的动态规划可以做哪些问题?我想知道可以使用Leetcode中的动态规划来解决哪些问题,对于初学者来说很容易。我一直在LeetCode上练习问题,我注意到有些问题被专门标记为“动态编程”(DP)。我了解DP的基础知识,例如将问题分解为子问题并存储这些子问题的......
  • 如何使用 for 循环在 python jupyter 笔记本中创建动态图?
    我正在学习本课关于用Python求解热方程。该课程指出,在求解热方程后,我们可以通过在循环中简单地调用pyplot.plot()来可视化解的动画图,其中下面的代码将动态绘制每次每个点的温度,从而得到一个动画情节(课程帖子中提供了动画情节的示例)。importnumpyfrommatplotlibi......
  • Python:动态爱心代码
    importrandomfrommathimportsin,cos,pi,logfromtkinterimport*CANVAS_WIDTH=640CANVAS_HEIGHT=480CANVAS_CENTER_X=CANVAS_WIDTH/2CANVAS_CENTER_Y=CANVAS_HEIGHT/2IMAGE_ENLARGE=11HEART_COLOR="#FF99CC"defcenter_......
  • C++分组背包问题_动态规划dp_背包_算法竞赛
    OIWiki上的详细讲解模型总结分组背包的问题模板:有nnn件物品和一个大小为mm......
  • 为什么 NumPy 标量与自定义序列相乘而不与列表相乘?
    我有一个问题要问NumPy专家。考虑一个NumPy标量:c=np.arange(3.0).sum()如果我尝试将它与自定义序列相乘,例如classS:def__init__(self,lst):self.lst=lstdef__len__(self):returnlen(self.lst)def_......
  • YOLOv8改进 | Neck | 注意力尺度序列融合的检测框架ASF-YOLO
    秋招面试专栏推荐:深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转......