最大连续子数组和 动态规划_剑指Offer算法题 33:连续子数组的最大和
题目描述
HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。给一个数组,返回它的最大连续子序列的和,你会不会被他忽悠住?(子向量的长度至少是1)。
解题思路
方法一:动态规划。
状态定义:定义dp[ i ]代表以元素nums[ i ]为结尾的连续子数组最大和。
转移方程:若dp[ i-1 ]<=0,说明dp[ i-1 ]对dp[ i ]产生负贡献,即 dp[ i-1 ] + nums[ i ]还不如nums[ i ]本身大。
- 当dp[ i - 1 ] > 0时:执行dp[ i ] = dp[ i - 1 ] + nums[ i ];
- 当dp[ i - 1 ] <= 0时:执行dp[ i ] = nums[ i ];
初始状态:dp[0] = nums[0],即以nums[0]结尾的连续子数组最大和为nums[0]。
时间复杂度:O(n);空间复杂度:O(1)
源码
public class Solution { public int FindGreatestSumOfSubArray(int[] array) { //动态规划 int result = array[0];
for(int i = 1; i //array[i]表示前一个数对该数求和做正贡献(保留)还是负贡献(舍弃) array[i] += Math.max(array[i - 1], 0);
//将目前得到的最大值与当前取得的最大值进行比较 result = Math.max(result, array[i]); }
return result; }}
运行结果
最大连续子数组和 动态规划_剑指Offer算法题 33:连续子数组的最大和相关推荐
- java统计一个字符串中每个字符出现的次数_剑指offer算法题054:字符流中第一个不重复的字符...
推荐阅读:宇宙条的工作总结:一年前还在面试找工作,一年后在面试找工作的学弟学妹们:第一次当面试官的经历分享小编在求职找找工作期间剑指offer上的算法题刷了很多遍,并且每道题小编当时都总结了一种最适合 ...
- 道指mt4代码_剑指offer算法题052:正则表达式匹配
小编在求职找找工作期间剑指offer上的算法题刷了很多遍,并且每道题小编当时都总结了一种最适合面试时手撕算法的最优解法.考虑到剑指offer算法题在面试中的高频出现,小编每天和大家分享一道剑指offe ...
- 剑指offer算法题028:数组中出现次数超过一半的数字
小编在求职找找工作期间剑指offer上的算法题刷了很多遍,并且每道题小编当时都总结了一种最适合面试时手撕算法的最优解法.考虑到剑指offer算法题在面试中的高频出现,小编每天和大家分享一道剑指offe ...
- 剑指offer算法题分析与整理(一)
下面整理一下我在刷剑指offer时,自己做的和网上大神做的各种思路与答案,自己的代码是思路一,保证可以通过,网友的代码提供出处链接. 目录 1.数组中的逆序对 2.二维数组中的查找 3.顺时针打印矩阵 ...
- 剑指offer算法题分析与整理(二)
下面整理一下我在刷剑指offer时,自己做的和网上大神做的各种思路与答案,自己的代码是思路一,保证可以通过,网友的代码提供出处链接. 目录 1.序列化二叉树 2.带记忆的DFS搜索 3.坐标数位和不大 ...
- 在数组中查找指定元素_剑指 offer 第一题: 二维数组中的查找
题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 ...
- 剑指offer算法题02
写在前面 主要是题目太多,所以和前面的分开来记录. 有很多思路的图都来源于力扣的题解,如侵权会及时删除. 不过代码都是个人实现的,所以有一些值得记录的理解. 七.动态规划 1. 斐波那契数列 题目:h ...
- 剑指offer算法题01
写在前面 主要是分类一下刷题遇到的一些题型. 有很多思路的图都来源于力扣的题解,如侵权会及时删除. 不过代码都是个人实现的,所以有一些值得记录的理解. 一.哈希表 1. 数组中重复的数字 题目描述:h ...
- 剑指offer算法题,输入一个链表,反转链表后,输出新链表的表头。
链表的算法题一直做的浑浑噩噩的,为了避免忘记以及能够及时的温故知新,所以将本次的解答记录如下: 话不多说,先贴代码: /* public class ListNode {int val;ListNod ...
最新文章
- 微信生态增长:裂变与分销讲解
- 去年领了163亿薪资的马斯克,刚推出智能召唤功能就被吐槽:遇到人开的车就蒙圈...
- 遍历Newtonsoft.Json.Linq.JObject
- sklearn模型预测性能评估(二)
- kubernetes高级之创建只读文件系统以及只读asp.net core容器
- Idea利用maven打包spring boot项目
- ***制作显身网络 公开销售***挑战法律界线
- javascript闭包小结
- 现控笔记(三):状态空间表达式的解
- Maven常见异常及解决方法---测试代码编译错误
- android java反编译
- 串口服务器如何设置485信号,串口服务器485 设置
- FreeSSL + ACME自动化续期域名SSL证书(支持泛域名)
- 定位到excel最后一个非空单元格操作技巧,你一定要知道!(一)
- Dedecms去掉所有版权
- 1196踩方格—递推方法!
- javaEE 深入理解 Session 与 Cookie
- [C++]牛客 WY11 星际穿越
- html+css制作圣诞树
- 二手车零售DTC黑马Carvana的全渠道策略