Python 程序,用于查找具有最大总和的连续子列表和
假设我们有一个数组 A。我们必须找到和最大的连续子列表,并返回其和。因此,如果数组 A 为 A = [-2,1,-3,4,-1,2,1,-5,4],则和将为 6。子数组将为 [4, -1, 2, 1]。
为解决此问题,我们将尝试使用动态规划方法。
定义一个数组 dp,大小与 A 相同,并用 0 填充
dp[0] := A[0]
i := 1 到 A 大小 – 1
dp[i] := dp[i – 1] + A[i] 和 A[i] 的最大值
返回 dp 中的最大值
让我们看看以下实现以获得更好的理解 −
示例
class Solution(object): def solve(self, nums): dp = [0 for i in range(len(nums))] dp[0] = nums[0] for i in range(1,len(nums)): dp[i] = max(dp[i-1]+nums[i],nums[i]) return max(dp) nums = [-2,1,-3,7,-2,2,1,-5,4] ob1 = Solution() print(ob1.solve(nums))
输入
[-2,1,-3,7,-2,2,1,-5,4]
输出
8
广告