53. Maximum Subarray
来源:互联网 发布:欧美电影推荐知乎 编辑:程序博客网 时间:2024/06/04 19:03
Find the contiguous subarray within an array (containing at least one number) which has the largest sum.
For example, given the array [-2,1,-3,4,-1,2,1,-5,4]
,
the contiguous subarray [4,-1,2,1]
has the largest sum = 6
.
题目含义:
在数组中找到连续的子序列(包含至少一个数字),其数量最大。
例如,给定数组[-2,1,-3,4,-1,2,1,-5,4],
连续子阵列[4,-1,2,1]的sum =最大6。
思想:简单的dp问题 设个数组dp[n]
dp[i]:(i为下标0....n)表示前i项以元素i结尾连续的子序列的最大值
动态转移方程:
dp[i-1]+sum[i] dp[i-1] >0
dp[i] =
sum[i] dp[i-1]<=0
C++AC代码:时间o(n) 空间o(n)
class Solution {public: int maxSubArray(vector<int>& nums) { int len = nums.size(); int dp[len]; int max; for(int i=0;i<len;i++){ if(i==0){ dp[i]=nums[i]; max = dp[i]; } else{ if(dp[i-1]>0) dp[i] = nums[i] + dp[i-1]; else dp[i] = nums[i]; } if(dp[i]>max) max = dp[i]; } return max; }};
参考别人的代码: 也是上面的思想 只是没必要使用dp保存每一个dp[i]的状态了
因为是求最大值,所以直接用个变量动态存储就行了 时间o(n) 空间o(1)
class Solution {public: int maxSubArray(vector<int>& nums) { int n = nums.size(); int ans = -2147483648; int sum = 0; for(int i=0;i<n;++i) { sum= sum+nums[i]; if(sum>ans) { ans=sum; } if(sum<0) { sum=0; } } return ans; }};
阅读全文
0 0
- [LeetCode]53.Maximum Subarray
- LeetCode --- 53. Maximum Subarray
- 53.Maximum Subarray
- [Leetcode] 53. Maximum Subarray
- [leetcode] 53.Maximum Subarray
- 53.Maximum Subarray
- 53. Maximum Subarray
- 【leetcode】53. Maximum Subarray
- [leetcode] 53.Maximum Subarray
- 【leetcode】53. Maximum Subarray
- 53. Maximum Subarray
- LeetCode 53. Maximum Subarray
- 53. Maximum Subarray
- [LeetCode]53. Maximum Subarray
- 53. Maximum Subarray LeetCode
- 53. Maximum Subarray
- [LeetCode]53. Maximum Subarray
- 53. Maximum Subarray
- 一段简答的JavaScript code
- Java语言的概述
- 以live555为例来分析H264码流的打包发送
- 工业以太网详解
- urllib对url的处理
- 53. Maximum Subarray
- RxJS异步通信之Subject和BehaviorSubject
- Android自定View-最简单的可拖拽式层叠卡片
- 模拟百度搜索框提示功能实例
- DrawerLayout 高仿QQ5.2双向侧滑菜单
- php利用堆栈 实现高级计算器
- 重排链表
- Java基础教程14-数组
- RLE行程长度压缩算法