浙大数据结构: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;
	
}
相关推荐
南境十里·墨染春水3 小时前
C++ 工厂模式:从入门到进阶,彻底掌握对象创建的艺术
开发语言·c++·算法
一拳一个呆瓜6 小时前
【STL】_SCL_SECURE_NO_WARNINGS
c++·stl
小小编程路7 小时前
C++ 异常 完整讲解
开发语言·c++
海清河晏1119 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
Frank学习路上10 小时前
【C++】面试:关键字与语法特性
c++·面试
liulilittle10 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
Irissgwe11 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
两片空白11 小时前
数据容器集合set/frozenset
数据结构
点云侠11 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
代码中介商12 小时前
跳表:高效查找的链表黑科技
数据结构