[leetcode] 第二周作业
来源:互联网 发布:js调用手机浏览器 编辑:程序博客网 时间:2024/06/05 05:03
题目来源: <LeetCode OJ> 53. Maximum Subarray
题目:
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
.
分析:
利用动态规划分析问题:
首先,定义子问题:
tmpSum[i]为以第i个元素结尾的最大连续子数组和
很显然在for循环遍历的过程中,只有两种情况:
1)tmpSum[i]重新以当前元素nums[i]开始
2)tmpSum[i]继续累加,即当前元素nums[i]+tmpSum[i-1]
在这里,实际上可以将tmpSum数组省去,直接用一个变量递推即可,因为只和前一次结果相关。
简而言之就是:
在加上当前nums[i]之前,如果tmpSum是小于0的,那么说明tmpSum起副作用,需要重新寻找起始数开始累加,
即重新以当前nums[i]为起始值开始累加
代码:
class Solution {public: int maxSubArray(vector<int>& nums) { int maxSum=INT_MIN,tmpSum=0; for(int i=0;i<nums.size();i++) { tmpSum=max(tmpSum+nums[i],nums[i]);//连续累加时的两种情况 maxSum=max(maxSum,tmpSum);//更新最大值 } return maxSum; }};
阅读全文
0 0
- [leetcode] 第二周作业
- 算法课程Leetcode作业第二周技术博客
- 第二周作业第二题
- 第二周作业
- 第二周作业
- 第二周作业
- 第二周作业
- 第二周作业
- 第二周作业 1
- 第二周作业 2
- 第二周作业 3
- 第二周作业 4
- 第二周作业 3
- Java第二周作业
- 第二周课后作业
- 网络第二周作业
- 第二周作业c++
- 第二周c++作业
- Mybatis配置文件中的mapUnderscoreToCamelCase属性
- Sublime text3 v3.0 build3143注册码
- Android--关于Fragment的基础介绍(二)
- 函数的参数
- win10 64位系统 微星GE62 安装Linux ubutuntu 系统Deepin的过程
- [leetcode] 第二周作业
- 数据类型转换:short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错? short s1=1,s2=1;short s3=s1+s2;
- 2017 ACM-ICPC 亚洲区(西安赛区)网络赛 Coin(组合数)
- http://localhost:63342/cloudcareer_pc/index.html?requested without authorization, you can......
- 日志文件相关等待
- 鸡兔同笼
- 设计模式——迭代器与组合模式(二)
- lucene.net在进行删除索引的时候注意
- pandas 安装