最大子段和 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);
	}
}

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

相关推荐
夕除8 小时前
spring boot 4
java·spring boot·后端
艾iYYY8 小时前
类和对象(详解初始化列表, static成员变量, 友元,内部类)
c语言·数据结构·c++·算法
asdzx678 小时前
使用 C# 添加或读取 Excel 公式:完整指南
开发语言·c#·excel
磊 子8 小时前
多继承和多态性
开发语言·c++
三产8 小时前
Hermes 教程 03:Skills 系统
android·java·数据库
加号38 小时前
【C#】 中 BCD 字节数组转十进制字符串的原理与实现思路
开发语言·c#
AbandonForce8 小时前
C++11:列表初始化||右值和移动语义||引用折叠和完美转发||可变参数模板||lambda表达式||包装器(function bind)
开发语言·数据结构·c++·算法
starsky762388 小时前
spring boot——前后端分离
java·spring boot·后端
jiayong238 小时前
IDEA 中进行分支双向同步操作指南
java·ide·intellij-idea
jghhh018 小时前
燃料电池电源 Matlab 仿真方案
开发语言·matlab