Maximum Subarray III
Given an array of integers and a number k, find k non-overlapping
subarrays which have the largest sum.
The number in each subarray should be contiguous.
Return the largest sum.
Notice
The subarray should contain at least one number
Given [-1,4,-2,3,-2,3]
, k=2
, return 8
这是一题划分类型的题目, 划分类型的题目只关心划分位,而不关心区间里面的内容.针对这题来说,我们只划分数组,并不是划分的区间内的所有数字形成的子数组就是我们在这个划分中要找的,可能是子子数组, 和区间型DP(Scramble String,Burst Balloons)形成了比较大的区别.这点需要注意. 也是划分类DP这种特点, 导致我们直接用类似区间型DP的定义方式,复杂度会很高,子子数组怎么复杂度很高.
所以此类题目一个比较好的解法是采用local, global双状态. local保存当前位置为结尾的局部最优状态, global保存全局最优状态.
如果采用传统解法:
state: f[i][j]表示前i个元素选了j次子数组,能够取得的最大值
function: f[i][j] = max{f[x][j-1] + subarray(x+1, i)} {x=0->i-1}
answer: f[n][k]
class Solution: """ @param nums: A list of integers @param k: An integer denote to find k non-overlapping subarrays @return: An integer denote the sum of max k non-overlapping subarrays """ def maxSubArray(self, nums, k): if not nums or not k: return 0 #local[i][j] the beginning ith elements forms j subarray locals = [[-sys.maxint] * (k+1) for i in xrange(len(nums)+1)] globals = [[-sys.maxint] * (k+1) for i in xrange(len(nums)+1)] for i in xrange(len(nums)+1): locals[i][0] = 0 globals[i][0] = 0 for i in xrange(1,len(nums)+1): for j in xrange(1, min(i,k)+1): locals[i][j] = max(locals[i-1][j], globals[i-1][j-1]) + nums[i-1] globals[i][j] = max(locals[i][j], globals[i-1][j]) return globals[len(nums)][k]
posted on 2016-07-02 17:00 Sheryl Wang 阅读(270) 评论(0) 编辑 收藏 举报