LeetCode-P53题解【动态规划】
本文为原创,转载请注明:http://www.cnblogs.com/kylewilson/
题目出处:
https://leetcode.com/problems/maximum-subarray/description
题目描述:
找出连续子区间最大和,至少包含一个数
例如:[-2,1,-3,4,-1,2,1,-5,4],则子区间[4,-1,2,1]有最大和为6
输入:
[-2,1,-3,4,-1,2,1,-5,4]
思路分析:

解法一:
如上图P1.1:
最优解一定为一段连续的区间,则可以有O(n*n)的解法,即遍历所有的区间找出最大值
设sum[i]为区间[1,i]的和,初始化处理
最优解=max(sum[i]-sum[j]), (0<=i,j<n)
解法二:
假设最大区间和为上图红色区域,可以看出,点i一定是该区间最右边节点;

图P1.2
设f[i]为以i结尾的最大连续区间和
为什么一定要以i结尾?
因为f[i]为一维数组,不加这个条件,则f[i]无法表示出前面的状态,只知道前i个节点的最优解,但不知道最优解从哪里开始
如果已经求出i个节点的最大区间和,则增加一个节点i+1时,前i+1个节点的最优解只有两种情况
1)i+1不在最优解区间中,这种情况和只有i个节点是一样的
2)i+1在最优解区间中, 这和情况i+1一定是最优解的最右边节点,又分两种情况
2-1) 前i个节点的最优解为负数,则舍弃前面的和,因为加上前面的和会更小
f[i+1]=f[i]+line[i+1]
2-2) 前i个节点的最优解为正数,则加上前面的和,因为加上前面的和会更大
f[i+1]=line[i+1]
最优解=max(f[i]), (0<=i<n)
注:每一个节点i只与之前的一个节点i-1相关,所以用滚动变量,空间复杂度为O(1)
C++源码如下:
github: https://github.com/Kyle-Wilson1/Leetcode/tree/master/P53
class Solution {
public:
Solution() = default;
static int maxOfTwo(int a, int b) {
return a > b ? a : b;
}
int maxSubArray(vector<int> &nums) {
int pre = 0, now = 0, maxAnswer = -2147483647;
for (int num : nums) {
if (pre > 0)
now = pre + num;
else
now = num;
maxAnswer = maxOfTwo(maxAnswer, now);
pre = now;
}
return maxAnswer;
}
};
LeetCode-P53题解【动态规划】的更多相关文章
- LeetCode OJ 题解
博客搬至blog.csgrandeur.com,cnblogs不再更新. 新的题解会更新在新博客:http://blog.csgrandeur.com/2014/01/15/LeetCode-OJ-S ...
- LeetCode总结 -- 一维动态规划篇
这篇文章的主题是动态规划, 主要介绍LeetCode中一维动态规划的题目, 列表如下: Climbing StairsDecode WaysUnique Binary Search TreesMaxi ...
- Leetcode 简略题解 - 共567题
Leetcode 简略题解 - 共567题 写在开头:我作为一个老实人,一向非常反感骗赞.收智商税两种行为.前几天看到不止两三位用户说自己辛苦写了干货,结果收藏数是点赞数的三倍有余,感觉自己的 ...
- LeetCode初级算法--动态规划01:爬楼梯
LeetCode初级算法--动态规划01:爬楼梯 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net ...
- LeetCode 算法题解 js 版 (001 Two Sum)
LeetCode 算法题解 js 版 (001 Two Sum) 两数之和 https://leetcode.com/problems/two-sum/submissions/ https://lee ...
- [LeetCode]Longest Palindromic Substring题解(动态规划)
Longest Palindromic Substring: Given a string s, find the longest palindromic substring in s. You ma ...
- leetcode & lintcode 题解
刷题备忘录,for bug-free 招行面试题--求无序数组最长连续序列的长度,这里连续指的是值连续--间隔为1,并不是数值的位置连续 问题: 给出一个未排序的整数数组,找出最长的连续元素序列的长度 ...
- LeetCode一句话题解
深度优先搜索 人生经验 1. 需要输出所有解.并由于元素集有重复元素,要求返回的结果需要去重的情况,可考虑使用值对应数量的map,然后分别考虑依次取不同数量该值的可能. LeetCode39 题目:给 ...
- [leetcode] 位操作题解
子集 题目[78]:给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 示例: 输入: nums = [1,2,3] 输出: [ [3], [1], [2], [ ...
- LeetCode 中等题解(1)
16 最接近的三数之和 Question 给定一个包括 n 个整数的数组 nums 和 一个目标值 target.找出 nums 中的三个整数,使得它们的和与 target 最接近.返回这三个数的和. ...
随机推荐
- 神奇的BFC
BFC是什么? 块格式化上下文(Block/box Formatting Context,BFC) 是Web页面的可视CSS渲染的一部分,是块盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域 ...
- Python十大装B语法!你会几种?
本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理 Python 是一种代表简单思想的语言,其语法相对简单,很容易上手.不过,如果就此小视 Python ...
- 【程序包管理】篇章3:CentOS平台下软件包安装方法总结
1.软件包安装前的学习:程序包管理的基础知识 2.程序包安装的方法介绍: rpm文件的二进制包安装:Linux程序包管理之rpm安装总结 yum安装:Linux程序包管理之yum源安装 链接:本地yu ...
- 前端技术VUE 的前世今生从PC 走向移动
一.Vue的前世 Vue 框架诞生于2014年,他的作者为中国人–尤雨溪(江苏无锡人).Vue用于构建交互式的Web界面的库,是一个构建数据驱动的Web界面渐进式框架,该框架遵循CMD规范,并且提供的 ...
- 前端可视化开发--liveload
在前端开发中,我们会频繁的修改html.css.js,然后刷新页面,开效果,再调整,再刷新,不知不觉会浪费掉我们很多时间.有没有什么方法,我在编辑器里面改了代码以后,只要保存,浏览器就能实时刷新.经过 ...
- kickstart+pxe部署
------------恢复内容开始------------ kickstart 通过网络安装系统 ----pxe kickstart,cobbler pex 预启动执行环境 通过网络接口启动计算机, ...
- three.js WebGLRenderTarget
今天郭先生说一说WebGLRenderTarget,它是一个缓冲,就是在这个缓冲中,视频卡为正在后台渲染的场景绘制像素. 它用于不同的效果,例如把它做为贴图使用或者图像后期处理.线案例请点击博客原文. ...
- git 只提交部分文件 拉取pull远程仓库
正常的团队开发中,在提交代码push之前要先pull拉取远程仓库的代码.而拉取pull操作需要先commit修改的文件才能成功. 那么问题来了,当我只想push提交部分代码的时候,同样需要pull拉取 ...
- VNC使用及其常见问题解决方法
博主之前在博文(https://www.cnblogs.com/kangbazi666/p/14153604.html)中已经介绍了多人VNC的配置方法,下面将简单介绍其使用方法及常见问题的解决方法. ...
- 冒泡排序算法JAVA实现版
/***关于冒泡排序,从性能最低版本实现到性能最优版本实现*/public class BubbleSortDemo { public static void sort(int array[]) { ...