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;
}
相关推荐
2401_86495928几秒前
C++与Python混合编程实战
开发语言·c++·算法
左左右右左右摇晃1 分钟前
Java并发——锁的状态演变
java·开发语言·笔记
2501_945424802 分钟前
C++与硬件交互编程
开发语言·c++·算法
2301_818419012 分钟前
C++中的表达式模板
开发语言·c++·算法
Roselind_Yi3 分钟前
排查Visual C++堆损坏(HEAP CORRUPTION)错误:从报错到解决的完整复盘
java·开发语言·c++·spring·bug·学习方法·远程工作
ZoeJoy88 分钟前
C# Windows Forms 学生成绩管理器(StudentGradeManager)—— 方法重载、out、ref、params 参数示例
开发语言·c#
千百元11 分钟前
网络图标显示不正常
开发语言·网络·php
Amumu1213814 分钟前
Js: ES新特性(一)
开发语言·前端·javascript
_日拱一卒15 分钟前
LeetCode:三数之和
算法·leetcode·排序算法
cm65432018 分钟前
C++中的原型模式变体
开发语言·c++·算法