假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
思路:
- 总思路:
- 动态规划四大步骤:
- (1)确定状态(两个核心:1、最后一步;2、化成子问题得状态方程);
- (2)建立状态转移方程;
- (3)确定开始和边界条件;
- (4)计算顺序;
- dp[i]用来表示,终点在i的子序列的最佳子序和,这样dp[i]和dp[i-1]之间便有简单明了的关系
- dp[i] = Math.max(dp[i - 1], 0) + num[i];
- 最后返回的值应该从dp数组中取最大值,即以i结尾的数组的最大子序和中找到最大的,作为整个数组的最佳子序和。
function maxSubArray(nums: number[]): number {
if(nums.length == 1) return nums[0];
let dp: number[] = [];
dp[0] = nums[0];
let max:number = dp[0];
for(let i=1; i<nums.length; i++) {
dp[i] = Math.max(dp[i - 1], 0) + nums[i];
if(dp[i]>max) max = dp[i];
}
return max;
};