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

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

相关推荐
零小陈上(shouhou6668889)2 分钟前
K-近邻算法 - lazy learning的代表
算法·近邻算法
Amumu121387 分钟前
React面向组件编程
开发语言·前端·javascript
有一个好名字8 分钟前
力扣-从字符串中移除星号
java·算法·leetcode
IT=>小脑虎8 分钟前
Python零基础衔接进阶知识点【详解版】
开发语言·人工智能·python
wjs202411 分钟前
C 标准库 - `<float.h>》详解
开发语言
萧瑟其中~12 分钟前
二分算法模版——基础二分查找,左边界查找与右边界查找(Leetcode的二分查找、在排序数组中查找元素的第一个位置和最后一个位置)
数据结构·算法·leetcode
码上就好ovo14 分钟前
Atcoder Beginnner Contest 440
算法
zfj32118 分钟前
CyclicBarrier、CountDownLatch、Semaphore 各自的作用和用法区别
java·开发语言·countdownlatch·semaphore·cyclicbarrier
高洁0121 分钟前
CLIP 的双编码器架构是如何优化图文关联的?(3)
深度学习·算法·机器学习·transformer·知识图谱