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

连续子数组的最大和

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

import java.util.*;
public class Solution {
    public int FindGreatestSumOfSubArray(int[] array) {
	  //创建DP数组
        int dp[]=new int[array.length];
	  //初始化DP数组
        dp[0]=array[0];
	  //对于当前位置的最长长度就是比较当前位置array数组元素和dp数组上一个位置的元素+当前array数组元素谁的值大
        for(int i=1;i<array.length;i++){
            dp[i]=Math.max(dp[i-1]+array[i],array[i]);
        }
	  //找到最大值
        int max=dp[0];
        for(int i=0;i<dp.length;i++){
            if(dp[i]>max){
                max=dp[i];
            }
        }
        return max;
    }
}

全部评论

相关推荐

程序员花海_:实习写的太偏技术了 分库分表这种一看就和应届生没关系
投递用友等公司9个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务