重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
给你一个整数数组 nums ,请你找出一个具有大和的连续子数组(子数组最少包含一个元素),返回其大和。
创新互联公司是一家专注于网站设计、成都网站建设与策划设计,忠县网站建设哪家好?创新互联公司做网站,专注于网站建设十年,网设计领域的专业建站公司;建站业务涵盖:忠县等地区。忠县做网站价格咨询:18982081108子数组 是数组中的一个连续部分。
示例输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和大,为 6 。
输入:nums = [1]
输出:1
题解思路:
动态规划
主要思路:
维护一个和nums数组长度相等的数组,用来记录1-i之间和大的那个
状态转移就是将nums[i] 和 nums[i] + dp[i - 1]相比较,哪个大就留下那个
代码:
var maxSubArray = function(nums) {const n = nums.length
// 创建dp数组
const dp = new Array(n).fill(Number.MIN_VALUE)
// 初始化dp数组
dp[0] = nums[0]
let res = dp[0]
// 状态转移
for(let i = 1;i< n;i++){dp[i] = Math.max(dp[i - 1] + nums[i], nums[i])
res = Math.max(res, dp[i])
}
return res
};
原题链接原题链接
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧