(java)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.

思路:还是典型的贪心,设置一个maxsum和sum,循环遍历这个数组,当maxsum <sum时,maxsum=sum;

当sum<0 时,将前面的丢弃,sum=0,重新开始;

注意边界nums[i]都是小于0的,返回那个最大的数。

代码如下(已通过leetcode)

public class Solution {
   public int maxSubArray(int[] nums) {
    boolean flag=true;
    int j=0;
    int temp=-Integer.MIN_VALUE;
    while(j<nums.length){
    if(nums[j]>0){
    flag=false;
    break;
    }
    if(nums[j]>temp) temp=nums[j];
    j++;
    }
    if(flag) return temp;
       int sum=0;
       int maxsum=0;
       for(int i=0;i<nums.length;i++){
        sum=sum+nums[i];
        if(sum>maxsum) maxsum=sum;
        if(sum<0) sum=0;
       }
       return maxsum;
   }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值