目录
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;
}
}