【算法题】53. 最大子数组和-力扣(LeetCode)

news/2024/9/21 17:31:05 标签: 算法, leetcode, 动态规划

算法题】53. 最大子数组和-力扣(LeetCode)

1.题目

下方是力扣官方题目的地址

53. 最大子数组和

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

子数组

是数组中的一个连续部分。

示例 1:

输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。

示例 2:

输入:nums = [1]
输出:1

示例 3:

输入:nums = [5,4,-1,7,8]
输出:23

提示:

  • 1 <= nums.length <= 105
  • -104 <= nums[i] <= 104

2.题解

思路

本题很显然可以用动态规划的思路

我们可以将该问题转换为子问题,找到这些子问题的状态转移方程

这个问题就可以轻松地解决了

我们用 dp[i] 代表以第 i个数结尾的连续子数组的最大和

dp[i]的得出有两种情况:

1.单独自成一个序列,从num[i]开始

2.加入dp[i-1]的那一段序列

由这两个情况可以很容易得出状态转移方程:

dp[i]=max(dp[i-1]+nums[i],nums[i])

得出了状态转移方程,这个问题也就迎刃而解了

Python代码

class Solution(object):
    def maxSubArray(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        dp=[0]*len(nums)        # 初始化dp数组
        dp[0]=nums[0]
        for i in range(1,len(nums)):
            dp[i]=max(dp[i-1]+nums[i],nums[i])      # 利用状态转移方程
        return max(dp)

3.结语

本人资历尚浅,发博客主要是记录与学习,欢迎大佬们批评指教!大家也可以在评论区多多交流,相互学习,共同成长。


http://www.niftyadmin.cn/n/5669165.html

相关文章

初级前端面试

1.介绍自己 2.介绍一下之前做过的项目以及接触的业务 3.最近学的技术&#xff0c;接触的是哪一块&#xff08;回答了vue3&#xff09; 4.vue3在什么时候调用接口 beforeCreate 在实例初始化之后&#xff0c;数据观测 (data observer) 和 event/watcher 事件配置之前被调用。 用…

Spring系统学习(一)——初识Spring框架

1. Spring 框架概述 1.1 什么是 Spring&#xff1f; Spring 是一个流行的基于 Java 的开源框架&#xff0c;旨在简化企业级应用程序的开发。最初&#xff0c;它是为了简化 Java 企业版&#xff08;Java EE&#xff09;的复杂性而设计的&#xff0c;经过不断发展&#xff0c;S…

【算法】算法思想合集

数组分块 将数组分成具有某些特征的段使用双指针算法&#xff08;如果是数组&#xff0c;使用下标充当指针&#xff09;存在信息丢失的问题&#xff0c;可以考虑从后向前进行利用单调性进行定性分析&#xff08;盛最多的水&#xff09; 滑动窗口同向移动的双指针出窗口一般是w…

Oracle11g安装配置详细教程

Oracle卸载重装比较麻烦&#xff0c;尽量一次成功&#xff0c;如果遇到问题实在解决不了&#xff0c;请后台私信我&#xff01; 1、下载oracle安装包 下载方式1&#xff1a;官网下载地址&#xff1a; https://docs.oracle.com/en/database/oracle/oracle-database/index.html …

Net core 环境变量

Environment.ExpandEnvironmentVariables&#xff08;“资源名称”&#xff09;

张养浩,文坛政坛的双重巨匠

张养浩&#xff0c;字希孟&#xff0c;号云庄&#xff0c;又称齐东野人&#xff0c;生于元世祖至元七年&#xff08;公元1270年&#xff09;&#xff0c;卒于元英宗至治三年&#xff08;公元1329年&#xff09;&#xff0c;享年59岁。他是中国元代著名的文学家、政治家&#xf…

SpringDataJpa自关联映射时出现StackOverflowError

使用Jpa自关联时&#xff0c;存在子数据的记录会报内存溢出问题StackOverflowError 原因&#xff1a; 使用了 lombok 插件中的Data注解来标注类&#xff0c;生成 gettet/setter 以及 toString lombok 在生成时会出现循环比较两类中的 hashcode&#xff0c;导致内存溢出。 解决…

海外大带宽服务器连接失败怎么办?

在全球化日益加深的今天&#xff0c;海外大带宽服务器已成为企业拓展国际市场、提升业务效率的重要工具。然而&#xff0c;面对复杂多变的网络环境和技术挑战&#xff0c;服务器连接失败的问题时有发生&#xff0c;这不仅影响了企业的正常运营&#xff0c;还可能带来经济损失和…