浙大数据结构:01-复杂度1 最大子列和问题

数据结构MOOC

PTA习题

01-复杂度1 最大子列和问题

使用在线处理,遍历数组,如果当前数组和小于0则抛弃,每次更新最大值。

我们假设最终结果为数组中间的一段,那么左边剩余的部分和右边剩余的部分和一定小于0,对答案没有贡献。

cpp 复制代码
#include <iostream>
using namespace std;

const int M=100005;
int a[M];
int main()
{
    int k;
    cin>>k;
    for(int i=0;i<k;i++ )cin>>a[i];

    int s=0,ma=0;
    for(int i=0;i<k;i++)
    {
        s+=a[i];
        ma=max(s,ma);
        if(s<0)
        {
            s=0;
        }
}
    cout<<ma;
    
	return 0;
	
}
相关推荐
醍醐三叶1 小时前
C++文件操作--2 二进制文件操作
开发语言·c++
int型码农1 小时前
数据结构第七章(四)-B树和B+树
数据结构·b树·算法·b+树
li星野1 小时前
C++:C++内存管理
开发语言·c++
溟洵1 小时前
【C++ Qt】布局管理器
开发语言·c++·qt
我家大宝最可爱1 小时前
c++动态链接库
开发语言·c++
乌萨奇也要立志学C++1 小时前
【C++详解】string各种接口如何使用保姆级攻略
c++
C++ 老炮儿的技术栈2 小时前
自定义CString类与MFC CString类接口对比
c语言·c++·windows·qt·mfc
卡戎-caryon2 小时前
【C++】15.并发支持库
java·linux·开发语言·c++·多线程
superior tigre3 小时前
C++学习:六个月从基础到就业——C++11/14:列表初始化
c++·学习
啊吧怪不啊吧3 小时前
C/C++之内存管理
开发语言·汇编·c++