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

连续子数组的最大和(二)

https://www.nowcoder.com/practice/11662ff51a714bbd8de809a89c481e21

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param array int整型vector 
     * @return int整型vector
     */
    vector<int> FindGreatestSumOfSubArray(vector<int>& array) {
        vector<int> res;
        vector<int> dp(array.size(), 0);
        if(array.size()==0) return res;
        int l=0, r=0;
        int ll=0, rr=0;
        int maxval=array[0];
        dp[0] = array[0];
        for(int i=1; i<array.size(); i++)
        {
            r++;
            if(dp[i-1]+array[i]<array[i])
            {
                dp[i] = array[i];
                l=r;
            }
            else if(dp[i-1]+array[i]>=array[i])
            {
                dp[i] = dp[i-1]+array[i];
            }
            if(dp[i]>=maxval)
            {
                ll = l;
                rr = r;
                maxval = dp[i];
            }

        }
        for(int i=ll; i<=rr; i++)
        {
            res.push_back(array[i]);
        }
        return res;
    }
};

磨砂的指名者 文章被收录于专栏

怎么绘世呢?

全部评论

相关推荐

11-15 18:39
已编辑
西安交通大学 Java
全村最靓的仔仔:卧槽,佬啥bg呢,本也是西交么
点赞 评论 收藏
分享
Java抽象带篮子:难蚌,点进图片上面就是我的大头😆
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务