java语言实现连续子数组最大和--牛客网

目录

1 题目描述

2 解题思路

3 代码实现


1 题目描述

输入一个整形数组(可能有正数和负数),求数组中连续子数组(最少有一个元素)的最大和。要求时间复杂度为O(n)。

 在写这个题的时候,测试用例从20%,60%,80%,90%,最终100%通过,必须要写篇博客好好记录一下了~

2 解题思路

刚开始想的是,定义一个方法,求出数组的最大字数组。定义一个变量num,sum,num记录数组求和,sum记录求得的和中最大的那个数,这其中还用到了Math中求最大值的函数max,但是测试用例没有完全通过~~~

最后通过查阅通过的代码,我深深的铭记住了一件事:还要考虑特殊情况--数组中全为负数的情况!

3 代码实现

import java.util.*;

public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] data = new int[n];
        for(int i = 0;i < n;i++){
            data[i] = sc.nextInt();
        }
        System.out.println(maxNumber(data));
    }
    public static int maxNumber(int[] data){
        int num = 0;
        //注意全负数的情况
        int sum = -10000;
        for(int i = 0;i < data.length;i++){
            num += data[i];
            if(num > sum){
                sum = num;
            }
            //若求得的数组和小于0,将num重新赋值
            if(num < 0){
                num = 0;
            }
        }
        return sum;
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值