当前位置: 首页 > news >正文

Leetcode No.53 Maximum Subarray

  参考资料:

  考点:子串 & 动态规划 & [题干]

Input: nums = [-2,1,-3,4,-1,2,1,-5,4]
Output: 6
Explanation: The subarray [4,-1,2,1] has the largest sum 6.

  1. 心路历程

  这道题非常经典,蕴含的思想也是精巧无比。

  2. 正解

  简单来说官解就是找到了题目中的无后效性,和问题的可分解性(动归)

  1)首先分解问题

  一个数组中的子串是相当多的,穷举显然不是理想的做法,那么最大的子串和等于什么??答:等于以每个数结尾的最大子串的最大值。以数组[-2,1,-3]为例,就是以-2为结尾的子串的最大值,以1为结尾的子串的最大值,和以3为结尾的子串的最大值。这三个最大值中的最大值显然就是原始字符串的最大值。我们可以敏锐的发现,以XX为结尾的子串的最大值这一个问题,是很容易拆分的。比如:以1为结尾的子串的最大值,就等于“以-2为结尾的子串的最大值加上1”和“1”之间的大者。显然可以记这个函数“以每个数结尾的最大子串的最大值”为F。

  2)确定F的递推公式

  还是以数组[-2, 1, -3]为例,F[0] = -2,我们有F[n + 1] = max(F[n] + nums[n+1], nums[n+1]) ,将F[n]都算出来后,他们中的最大值显然就是我们想要的结果了。

  代码如下:

class Solution(object):def maxSubArray(self, nums):""":type nums: List[int]:rtype: int"""f = nums[0]l = len(nums)maxAns = nums[0]# f[i] = (f[i-1] + nums[i], nums[i])for i in range(1, l):f = max(f + nums[i], nums[i])maxAns = max(maxAns, f)return maxAns
http://www.lryc.cn/news/127960.html

相关文章:

  • 手机出现 不读卡 / 无信号时应该怎么办?
  • Linux 内核模块运行机制(10/11)
  • MySQL数据库-字符串函数详解
  • 半导体退火那些事(3)
  • 1281. 整数的各位积和之差
  • 如何使用Vue和C++实现OJ《从零开始打造 Online Judge》
  • 在Spring Boot和Vue中实现请求过滤器以验证请求头中的Token
  • ThreeJS——在3D地球上标记中国地图板块
  • 第2章 性能测量
  • 未来,运营的重要性大于产品?
  • paddle ocr框架识别数字问题和解决方案
  • 构建高性能的MongoDB数据迁移工具:Java的开发实践
  • 2023年国赛数学建模思路 - 案例:最短时间生产计划安排
  • 1572. 矩阵对角线元素的和
  • 在vue中使用swiper轮播图(搭配watch和$nextTick())
  • Java书签 #使用MyBatis接入多数据源
  • 神经网络基础-神经网络补充概念-23-神经网络的梯度下降法
  • 鸿蒙3.1 设备管理DeviceManager
  • Git 目录详解
  • 基于springboot+vue的武汉旅游网(前后端分离)
  • 步入React正殿 - React组件设计模式
  • Java 单例模式简单介绍
  • 根据源码,模拟实现 RabbitMQ - 从需求分析到实现核心类(1)
  • 企业服务器数据库遭到malox勒索病毒攻击后如何解决,勒索病毒解密
  • udp与can通信的选择与比较
  • HoudiniVex笔记_P24_ForceBasics力基础
  • 半导体退火那些事(1)
  • MapReduce介绍
  • Redis支持的主要数据结构操作命令有哪些?
  • 环境与能源创新专题:地级市绿色创新、碳排放与环境规制数据