题解 | 子数组绝对值的最大值

子数组绝对值的最大值

https://www.nowcoder.com/practice/200e7c7ad80741428c35119098aa39d1

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>
int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int n;
    cin>>n;
    vector<int>s(n);
    for(int i=0;i<n;i++){
        cin>>s[i];
    }
    int Max=s[0];
    int curMax=s[0];
    int Min=s[0];
    int curMin=s[0];
    for(int i=1;i<n;i++){
        curMax=max(s[i],curMax+s[i]);
        curMin=min(s[i],curMin+s[i]);
        Max=max(Max,curMax);
        Min=min(Min,curMin);
    }
    long long ans=max(abs(Max),abs(Min));
    cout<<ans<<endl;
    return 0;
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

10-28 17:30
已编辑
华东交通大学 Java
想进开水团喝开水:字节的hr的本职工作就是黄金矿工
秋招笔试记录
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务