OJ_最大序列和

题干

C++实现

cpp 复制代码
#include <stdio.h>
#include <algorithm>
using namespace std;

long long s[1000001];
long long dp[1000002];//dp[i]是前i个元素中必须包含右边缘的最大子序和

int main() {
    int n;
    scanf("%d",&n);
    for(int i = 0; i< n;i++){
        scanf("%lld",&s[i]);
    }

    dp[1] = s[0];
    long long curmax = dp[1];
    for(int i = 2;i<=n;i++){
        if(dp[i-1] <= 0){
            dp[i] = s[i-1];
        }else{
            dp[i] = s[i-1]+dp[i-1];
        }
        curmax = max(dp[i],curmax);
    }
    printf("%lld",curmax);
    return 0;
}
相关推荐
济宁雪人2 分钟前
Java安全基础——JNI安全基础
java·开发语言
地平线开发者6 分钟前
征程 6 | QAT 新版 qconfig 量化模板使用教程
算法·自动驾驶
lsx20240617 分钟前
Django 视图详解
开发语言
多恩Stone17 分钟前
【ModelScope-1】数据集稀疏检出(Sparse Checkout)来下载指定目录
人工智能·python·算法·aigc
h***066524 分钟前
【JSqlParser】Java使用JSqlParser解析SQL语句总结
java·开发语言·sql
代码or搬砖34 分钟前
Java Lambda 表达式全面详解
java·开发语言·python
山峰哥35 分钟前
沉浸式翻译插件深度评测:打破语言壁垒的黑科技利器
数据结构·科技·算法·编辑器·办公
这周也會开心43 分钟前
JDK1.8新增语法
java·开发语言
心随雨下1 小时前
TypeScript泛型开发常见错误解析
java·开发语言·typescript
AI脚下的巨人1 小时前
机器人逆运动学:从SVD到IK算法
算法·机器人