题解 | 最大连续子序列

最大连续子序列

https://www.nowcoder.com/practice/afe7c043f0644f60af98a0fba61af8e7

#include <iostream>
#include<cstring>
using namespace std;

const int MIN = 0xc0c0c0c0;
const int N = 10010;
int f;
int a[N];
int main() {
    int n;
    while (cin >> n) { // 注意 while 处理多个 case
        if (n == 0)break;
        // memset(f,0xc0,sizeof f);
        for (int i = 1; i <= n; i++) {
            cin >> a[i];
        }
        //由于要找最左边的端点所以f[i]的定义是以i为左端点的最长连续子序列
        //f[i]=max(f[i+1],0)+a[i]
        //g存放当前序列的右端点
        //right存放最大子序列的右端点
        int res = 0, left = 0, right = 0;
        int g ;
        for (int i = n, f = 0, g = n; i >= 0; i--) {
            //此时f是i+1状态的f
            if (f <= 0) {
                //取等就是为了找到最左边的端点
                f = 0;
                g = i;
            }
            f += a[i];
            if (res < f) {
                //更新最大连续子序列
                res = f;
                left = i;
                right = g;
            }
        }
        printf("%d %d %d\n", res, a[left], a[right]);
    }
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

05-14 16:55
广州大学 Java
面试情况25届双非本科,有&nbsp;ACM&nbsp;竞赛经历,两段实习(小厂&nbsp;+&nbsp;独角兽)。以下为2024年11月到次年5月的春招及其补录面试情况,若对个人秋招经历感兴趣,可查看另一篇置顶文章。通过某区级供水国企汇丰科技:线上行为测评&nbsp;→&nbsp;Coding&nbsp;测试&nbsp;→&nbsp;线下技术&nbsp;&amp;&nbsp;HR&nbsp;面东方财富:一、二轮线上面,三轮线下技术面招银科技:一轮线上技术,二轮、三轮线下技术和HR元戎启行:三轮技术面&nbsp;+&nbsp;HR&nbsp;面,一共四面面试挂拼多多:客户端,三轮技术面挂,手撕没撕出来4399:一轮技术面挂微派:一轮技术面挂,手撕没撕出来以下是个人无意向故提前主动终止流程,以免影响其他候选人广州农商银行:线下笔试,一轮面试...
isjsns:同双非本,最后的总结那块挺赞同的,我们计院的就业数据也就那样,年包二十到四十万的人也有,但少之又少,周围有认识的地信和电子的也有二到四十万的,找的还不错的包括我基本都是春招才找到的,个人是感觉春招机会挺多的,也可能是像楼主一样年初又找了个实习加技术又沉淀了一波的原因,本来秋招结束都想摆了,最后还是熬出来了大家别放弃啊,双非本也有翻身的机会的
点赞 评论 收藏
分享
没有offer的呆呆:薪资有的时候也能说明一些问题,太少了活不活得下去是一方面,感觉学习也有限
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务