题解 | #连续子数组的最大和#

连续子数组的最大和

http://www.nowcoder.com/practice/459bd355da1549fa8a49e350bf3df484

参考自链接
  我们分析一下这道题,全局最优解是序列子数组的最大和,但是这里我们可以把这道题进行一个拆分:
  1.求以arr[i]结尾的子数组最大和组成的数组dp
  2.数组dp中求最大值
  这样我们就可以得到一个dp方程:dp[n] = Max(dp[n - 1] + arr[n], arr[n]);(这道题的难点就在于这里,需要进行一个转换

class Solution {
public:

    int FindGreatestSumOfSubArray(vector<int> arr) {
        int length = arr.size();
        int max = arr.at(0);
        vector<int> dp (length, 0);
        dp.at(0) = arr.at(0);
        for(int i = 1; i < length; ++i)
        {
            dp.at(i) = std::max(dp.at(i - 1) + arr.at(i), arr.at(i));
            max = std::max(dp.at(i), max);
        }
        return max;
    }
};
全部评论

相关推荐

头像
02-15 16:23
中南大学 Java
野猪不是猪🐗:签了美团真是不一样! 亲戚们都知道我签了美团,过年都围着我问送一单多少钱,还让弟弟妹妹们引以为戒,笑我爸我妈养了个🐢孩子,说从小就知道我这个人以后肯定没出息,我被骂的都快上天了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务