最大子段和 Java

java 复制代码
import java.util.*;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		int[] dp = new int[n + 1];
		int max = Integer.MIN_VALUE;
		for (int i = 1; i <= n; i++) {
			int a = sc.nextInt();
            // 每次判断以a结尾的子数列和,只要前一个子数列和是大于零的,那么就加上它使自身增大,否则不加,从自身开始新的子数列
			dp[i] = dp[i - 1] > 0 ? a + dp[i - 1] : a;
			if (dp[i] > max) max = dp[i];
		}
		System.out.println(max);
	}
}

每日一水~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

相关推荐
回忆是昨天里的海几秒前
k8s集群-节点间通信之安装kube-flannel插件
java·docker·kubernetes
John.Lewis2 分钟前
C++初阶(14)list
开发语言·c++·笔记
爱学习的小鱼gogo7 分钟前
pyhton 螺旋矩阵(指针-矩阵-中等)含源码(二十六)
python·算法·矩阵·指针·经验·二维数组·逆序
信仰_27399324313 分钟前
Mybatis-Spring重要组件介绍
java·spring·mybatis
盖世英雄酱5813613 分钟前
java深度调试【第二章通过堆栈分析性能瓶颈】
java·后端
没有bug.的程序员23 分钟前
AOP 原理深剖:动态代理与 CGLIB 字节码增强
java·spring·aop·动态代理·cglib
2401_8370885023 分钟前
ResponseEntity - Spring框架的“标准回复模板“
java·前端·spring
坚持编程的菜鸟42 分钟前
LeetCode每日一题——二进制求和
c语言·算法·leetcode
hsjkdhs1 小时前
C++文件操作
开发语言·c++
hoiii1871 小时前
C#实现近7天天气预报
开发语言·c#