题目:有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元数组的子数组之和的最大值的更多相关文章

  1. 求数组的子数组之和的最大值III(循环数组)

    新的要求:一维数组改成循环数组,只是涉及简单算法,只是拿了小数做测试 想法:从文件读取数组,然后新建数组,将文件读取的数组在新数组中做一下连接,成为二倍长度的数组,然后再遍历,将每次遍历的子数组的和存 ...

  2. 求数组的子数组之和的最大值II

    这次在求数组的子数组之和的最大值的条件下又增加了新的约束:  1.要求数组从文件读取.      2.如果输入的数组很大,  并且有很多大的数字,  就会产生比较大的结果 (考虑一下数的溢出), 请保 ...

  3. C#中求数组的子数组之和的最大值

    <编程之美>183页,问题2.14——求子数组的字数组之和的最大值.(整数数组) 我开始以为可以从数组中随意抽调元素组成子数组,于是就有了一种想法,把最大的元素抽出来,判断是大于0还是小于 ...

  4. 求数组的子数组之和的最大值IV

    在之前的基础上又安排了二维数组的,在课上一开始是理解错要求了,简单的以为用循环数组就能解决,但是却忽视了子数组是否能构成矩形,之后课下和同学们讨论,主要是多重遍历,但是我还是没搞明白怎么构成新的二维数 ...

  5. 求二维数组联通子数组和的最大值 (联通涂色) beta!

    算法十分臃肿,效率捉鸡,不知用了多少循环,还有bug...任重道远,编程之美. 思想:按行遍历,找出每行的最大子数组.若行间都联通,行最大子数组相加后,再加上独立的正数.若行间不连通,找出较大子路径, ...

  6. [LeetCode] Minimum Size Subarray Sum 最短子数组之和

    Given an array of n positive integers and a positive integer s, find the minimal length of a subarra ...

  7. lintcode:子数组之和为0

    题目: 子数组之和 给定一个整数数组,找到和为零的子数组.你的代码应该返回满足要求的子数组的起始位置和结束位置 样例 给出[-3, 1, 2, -3, 4],返回[0, 2] 或者 [1, 3]. 解 ...

  8. Minimum Size Subarray Sum 最短子数组之和

    题意 Given an array of n positive integers and a positive integer s, find the minimal length of a suba ...

  9. [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 ...

随机推荐

  1. MAC的一些实用

    重置Dock, Launchpad defaults write com.apple.dock ResetLaunchPad -bool true; killall Dock;

  2. 【原创】Eclipse中为SVN设置快捷键

            SVN是深受开发者喜爱的版本控制工具,其较CVS有更好的控制策略.在Android开发中,我也选择SVN作为版本控制工具.Eclipse的SVN插件名叫Subclipse,可以到htt ...

  3. C# 字符串计算表达式

     C#  字符串计算表达式 string str="4+4+2.1"; 要的效果: double sum=4+4+2.1: 方案一: 动态计算表达式: 1 public class ...

  4. git的使用--不错的博客【转】

    转自:http://www.cnblogs.com/wang_yb/p/3867221.html GIT 的常规操作 常规操作也是我自己平时常用的几个命令, 学自于 pro git 这本书中 git ...

  5. (五)ASP.NET中动态生成控件

    今天被问到如何在ASP.NET 页面中动态创建一批控件,并且希望在后续代码中能访问到这些动态创建的控件.我用下面的例子来解释这个问题 ================================= ...

  6. MySQL工具:管理员必备的10款MySQL工具

    MySQL是一个复杂的的系统,需要许多工具来修复,诊断和优化它.幸运的是,对于管理员,MySQL已经吸引了很多软件开发商推出高品质的开源工具来解决MySQL的系统的复杂性,性能和稳定性,其中大部分是免 ...

  7. POJ-2718 Smallest Difference

    http://poj.org/problem?id=2718 从一些数里面选择一个子集组成一个数,余下的数组成另外一个数,(数不能以0开头)问两个数的差的绝对值最小是多少! 不管是奇数还是偶数,要想绝 ...

  8. NDK(11)Android.mk编译APK模板

    转自 :  http://hubingforever.blog.163.com/blog/static/1710405792011656434982/ 以下仅是使用Android.mk编译APK程序的 ...

  9. [HDOJ1043]Eight(康托展开 BFS 打表)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1043 八数码问题,因为固定了位置所以以目标位置开始搜索,把所有情况(相当于一个排列)都记录下来,用康托 ...

  10. Android 工程在4.0基础上混淆

    Android现在对安全方面要求比较高了,我今天要做的对apk进行混淆,用所有的第三方工具都不能反编译,作者的知识产权得到保障了,是不是碉堡了. 一,首先说明我这是在4.0基础上进行的. 先看看pro ...