这道题是LeetCode里的第53道题。

题目描述:

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

示例:

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

进阶:

如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的分治法求解。

简单的动态规划题,如果之前接触过动态规划的话很容易得出答案,没有的话估计得想一阵子。

不多废话,我先介绍一下什么是动态规划吧:动态规划(Dynamic Programming)是一种分阶段求解决策问题的数学思想。总的来说就是“大事化小,小事化了”。

动态规划中包含的三个重要概念:

  1. 最优子结构
  2. 边界
  3. 状态转移方程

就拿这道题目来说,假设输入[-2,1,-3,4,-1,2,1]数组,要求其连续子数组的最大和。那它的最优子结构是什么?注意到题目要求的是连续子数组最大和。既然这样,那么求[-2,1,-3,4,-1,2,1]的连续子数组的最大和,去掉其最后一位,就可以转为求[-2,1,-3,4,-1,2]的连续子数组的最大和,因为这样可以保证它是连续的。而求[-2,1,-3,4,-1,2]的连续子数组的最大和,又是求[-2,1,-3,4,-1]的连续子数组的最大和。这样一步一步简化它。边界就是问题的范围,不可能是无穷大。这个题目的边界就是原数组的长度7。而状态转移方程呢?这是最难找的。在这里我们假设res变量保存结果即最大和,sum变量保存子结构的连续和。就拿这个例子来说。

第一步:sum<0,sum=1,sum>res→res=sum=1(sum初值为-2,res初值为0)

第二步:sum>0,sum=sum+(-3)=-2,sum<res→res=res=1

第三步:sum<0,sum=4,sum>res→res=sum=4

第四步:sum>0,sum=sum+(-1)=3,sum<res→res=res=4

第五步:sum>0,sum=sum+2=5,sum>res→res=sum=5

第六步:sum>0,sum=sum+1=6,sum>res→res=sum=6

到达边界结束

代码如下:

class Solution {
public:
int maxSubArray(vector<int>& nums) {
int res = nums[0];
int sum = 0;
for(int num : nums){
if(sum > 0)sum += num;
else sum = num;
res = res>sum?res:sum;
}
return res;
}
};

第六行的代码是一个迭代器遍历,对于数组来说,等同于

for(int i=0;i<nums.length;i++){

int num=nums[i];

......

}

运行结果:

个人总结:

第一次正式接触动态规划题目,感觉动态规划题是我的短板,需要多加练习。这次也学到了新语法。

【LeetCode】Maximum Subarray(最大子序和)的更多相关文章

  1. 【LeetCode】53. Maximum Subarray 最大子序和 解题报告(Python & C++ & Java)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 暴力解法 动态规划 日期 题目地址: https:/ ...

  2. LeetCode 53. Maximum Subarray最大子序和 (C++)

    题目: Given an integer array nums, find the contiguous subarray (containing at least one number) which ...

  3. [LeetCode] Maximum Subarray 最大子数组

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  4. 53. Maximum Subarray最大子序和

    网址:https://leetcode.com/problems/maximum-subarray/submissions/ 很简单的动态规划 我们可以把 dp[i] 表示为index为 i 的位置上 ...

  5. 053 Maximum Subarray 最大子序和

    给定一个序列(至少含有 1 个数),从该序列中寻找一个连续的子序列,使得子序列的和最大.例如,给定序列 [-2,1,-3,4,-1,2,1,-5,4],连续子序列 [4,-1,2,1] 的和最大,为 ...

  6. [LintCode] Maximum Subarray 最大子数组

    Given an array of integers, find a contiguous subarray which has the largest sum. Notice The subarra ...

  7. LEETCODE —— Maximum Subarray [一维DP]

    Maximum Subarray Find the contiguous subarray within an array (containing at least one number) which ...

  8. LeetCode: Maximum Subarray 解题报告

    Maximum Subarray Find the contiguous subarray within an array (containing at least one number) which ...

  9. [LeetCode]Maximum Subarray题解

    Maximum Subarray: Find the contiguous subarray within an array (containing at least one number) whic ...

随机推荐

  1. SpringBoot学习笔记-Chapter2(hello word)

    开篇 第一次在博客园上写博客,初衷是想记录一下学习笔记,以往都是用笔去记录下学习笔记,现在来看在效率.检索速度上以及可可复制性都不好.作为一名Java开发人员 不会Spring Boot一定会被鄙视的 ...

  2. [POJ1185][NOI2001]炮兵阵地 状压DP

    题目链接:http://poj.org/problem?id=1185 很裸的状压,考虑对于一行用二进制储存每一种的状态,但是状态太多了做不了. 观察到有很多状态都是不合法的,于是我们预处理出合法的状 ...

  3. node.js之Windows 系统下设置Nodejs NPM全局路径

    node.js 0.10 版本下修改全局路径: npm config set cache "D:\nodejs\node_cache" npm config set prefix ...

  4. Spring MVC能响应HTTP请求的原因?

    很多Java面试官喜欢问这个问题: 一个Spring MVC的项目文件里,开发人员没有开发自己的Servlet,只通过注解@RequestMapping定义了方法home能响应发向 /mvc/test ...

  5. leetcode 127 单词接龙

    给定两个单词(beginWord 和 endWord)和一个字典,找到从 beginWord 到 endWord 的最短转换序列的长度.转换需遵循如下规则: 每次转换只能改变一个字母. 转换过程中的中 ...

  6. codeforces Gym 100338C Important Roads (重建最短路图)

    正反两次最短路用于判断边是不是最短路上的边,把最短路径上的边取出来建图.然后求割边.注意重边,和卡spfa. 正权,好好的dijkstra不用,用什么spfa? #include<bits/st ...

  7. SSave ALAsset image to disk fast on iOS

    I am using ALAsset to retrieve images like that: [[asset defaultRepresentation] fullResolutionImage] ...

  8. 解决因为手机设置字体大小导致h5页面在webview中变形的BUG

    首先,我们做了一个H5页面,在各种手机浏览器中打开都没问题.我们采用了rem单位进行布局,通过JS来动态计算网页的视窗宽度,动态设置html的font-size,一切都比较完美. 这时候,你自信满满的 ...

  9. 插入函数概念 接收一个callback,然后外面函数,接一个对象,和一个next,外面都执行完了,继续执行下一个函数,相当于一个链状体,插入了一个函数的概念 | log4js 输出 等于 console.info

    插入函数概念 接收一个callback,然后外面函数,接一个对象,和一个next,外面都执行完了,继续执行下一个函数,相当于一个链状体,插入了一个函数的概念 app.use(function (ctx ...

  10. javascript 中设置window.location.href跳转无效问题解决办法

    javascript 中设置window.location.href跳转无效问题解决办法 问题情况 JS中设置window.location.href跳转无效 原因是 a标签的href跳转会执行在wi ...