N元数组的子数组之和的最大值
题目:有N个整数的元素的一维数组,求子数组中元素之和中最大的一组(思想:动态规划)
分析:
设该数组为array[N], 那么对于array[i]该不该在元素之和最大的那个子数组中呢?首先,不如假设array[0..i-1]这个子数组的元素之和最大的子数组已求出,且和为Max,起始编号为start,结束编号为end, temp[i] 记录将array[i]强制加入到array[0..i-1]的元素之和最大的子数组中(比如数组:1, -3] 则temp[2] = -2, 虽然1才是最大和Max);
如果array[i]加入到array[0..i-1]的元素和最大的子数组中,那么必须:
temp[i - 1] + array[i] > Max; 确定只有着一个条件么? 非也,如果array[i] > temp[i - 1] + array[i] > Max呢(即Max<0)?这个时候,整个array[0..i]元素组成的子数组中最大和应该变为新的array[i]的值, 且start的新的值为i, end也为i,且temp[i] = array[i];
如果temp[i-1] + array[i] < Max, 这说明array[i]是一个负数,那么array[0..i]元素组成的子数组中和最大仍未Max, 且start, end都为变化;
根据上述思想,依次求得array[0..i](i=0, 1, 2...N)的子数组的子数组元素最大和对应的问题结果,
例子:
如s[6] = {3, -6, 8, 7, -2, 5}, 首先
对于3: start = end = 0; Max = 3; temp[0] = 3
3, -6: temp[0] + array[1] = -3 < Max, 此时start = end = 0; Max = 3; temp[1] = temp[0] + array[1] = -3
3, -6, 8: Max < temp[1] + array[2] = 5 < array[2], 此时start = end = 2; Max = 8; 由于start的值发生了变化, 此时temp[2]应作新的处理,即temp[2] = array[2] = 8;
3, -6, 8, 7: Max < temp[2] + array[3] = 15, 此时start = 2, end = 3, temp[3] = temp[2] + array[3]= 15; Max = 15,
3, -6, 8, 7, -2: temp[3] + array[4] < Max, 此时start =2, end = 3, Max = 15(三者不变), temp[4] = temp[3]+ array[4] = 13
3, -6, 8, 7, -2, 5: Max < temp[4] + array[5], 此时start = 2(不变) end+=1,即end=5, temp[5] = temp[4] + array[5] = 18 结束
代码(golang):
package main
import (
"fmt"
)
func main() {
array := []int{, -, , , -, }
lenth := len(array);
start, end := ,
var t int
Max := array[start]
temp := make([]int, lenth)
for i := ; i < lenth; i++ {
t = array[i] + temp[i - ]
if t <= array[i] {
start = i
end = i
temp[i] = array[i]
Max = array[i]
} else {
if t > Max {
end = i
Max = t
}
temp[i] = t
}
}
fmt.Println("Max subarray's sum: ", Max, " from ", start, "to ", end)
}
N元数组的子数组之和的最大值的更多相关文章
- 求数组的子数组之和的最大值III(循环数组)
新的要求:一维数组改成循环数组,只是涉及简单算法,只是拿了小数做测试 想法:从文件读取数组,然后新建数组,将文件读取的数组在新数组中做一下连接,成为二倍长度的数组,然后再遍历,将每次遍历的子数组的和存 ...
- 求数组的子数组之和的最大值II
这次在求数组的子数组之和的最大值的条件下又增加了新的约束: 1.要求数组从文件读取. 2.如果输入的数组很大, 并且有很多大的数字, 就会产生比较大的结果 (考虑一下数的溢出), 请保 ...
- C#中求数组的子数组之和的最大值
<编程之美>183页,问题2.14——求子数组的字数组之和的最大值.(整数数组) 我开始以为可以从数组中随意抽调元素组成子数组,于是就有了一种想法,把最大的元素抽出来,判断是大于0还是小于 ...
- 求数组的子数组之和的最大值IV
在之前的基础上又安排了二维数组的,在课上一开始是理解错要求了,简单的以为用循环数组就能解决,但是却忽视了子数组是否能构成矩形,之后课下和同学们讨论,主要是多重遍历,但是我还是没搞明白怎么构成新的二维数 ...
- 求二维数组联通子数组和的最大值 (联通涂色) beta!
算法十分臃肿,效率捉鸡,不知用了多少循环,还有bug...任重道远,编程之美. 思想:按行遍历,找出每行的最大子数组.若行间都联通,行最大子数组相加后,再加上独立的正数.若行间不连通,找出较大子路径, ...
- [LeetCode] Minimum Size Subarray Sum 最短子数组之和
Given an array of n positive integers and a positive integer s, find the minimal length of a subarra ...
- lintcode:子数组之和为0
题目: 子数组之和 给定一个整数数组,找到和为零的子数组.你的代码应该返回满足要求的子数组的起始位置和结束位置 样例 给出[-3, 1, 2, -3, 4],返回[0, 2] 或者 [1, 3]. 解 ...
- Minimum Size Subarray Sum 最短子数组之和
题意 Given an array of n positive integers and a positive integer s, find the minimal length of a suba ...
- [LeetCode] 209. Minimum Size Subarray Sum 最短子数组之和
Given an array of n positive integers and a positive integer s, find the minimal length of a contigu ...
随机推荐
- Tomcat中xml文件引入各种schma xsd问题原理
1.Tomcat下的xml引入各种xsd约束,其实是为了对应xml中用到的各个标签
- 瞬态电压抑制二极管(TVS)选用原则
在选用瞬态电压抑制二极管(TVS)时,必须考虑电路的具体条件,一般应遵循以下原则: 一.大箝位电压Vc(MAX)不大于电路的最大允许安全电压. 二.最大反向工作电压(变位电压)VRWM不低于电路的最大 ...
- keil MDK中如何生成*.bin格式的文件
在Realview MDK的集成开发环境中,默认情况下可以生成*.axf格式的调试文件和*.hex格式的可执行文件.虽然这两个格式的文件非常有利于ULINK2仿真器的下载和调试,但是ADS的用户更习惯 ...
- 让浏览器屏蔽js
有时候为了测试js是否做到了渐进增强,需要屏蔽下js 做法: Internet选项>>安全>>自定义级别 禁用java小程序脚本和活动脚本 有的浏览器调试器直接就有这个功能
- http://my.oschina.net/u/2007041/blog/508520
http://my.oschina.net/u/2007041/blog/508520
- Jquery中用offset().top和offsetTop的比较
今天,想测试一个div与顶部的距离,用的是.offsetTop,但是offsetTop获得的值,怎么都打印不出来.折腾了半天,打印的结果都是undefined,虽然网上很多资料都说返回的是数值.虽然这 ...
- PV UV
定义 PV: Page View 页面浏览量或点击量,用户每次刷新即被计算一次. UV: Unique Visitor 就是有多少个IP数量.就是指的有多少人在访问你的店.每个人用的电脑 ...
- 解决Android开发中,ActiveAndroid和Gson同时使用,对象序列化失败的问题
ActiveAndroid是安卓开发常用的ORM框架. Gson则是Google提供的轻量级序列化框架,非常适合Android开发使用. 但这两者同时使用,会产生序列化失败的问题.你通常会收到如下信息 ...
- java实现给图片添加水印
package michael.io.image; import java.awt.AlphaComposite; import java.awt.Graphics2D; import java.aw ...
- HttpClient 4.x 执行网站登录并抓取网页的代码
HttpClient 4.x 的 API 变化还是很大,这段代码可用来执行登录过程,并抓取网页. HttpClient API 文档(4.0.x), HttpCore API 文档(4.1) pack ...