浙大数据结构: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;
	
}
相关推荐
自我意识的多元宇宙12 小时前
【数据结构】平衡二叉树
数据结构
睡觉就不困鸭12 小时前
第十六天 反转字符串II
数据结构
测绘第一深情12 小时前
租用GPU云服务器进行深度学习(AutoDL,超保姆级,适用新手)
数据结构·人工智能·经验分享·python·深度学习·算法·计算机视觉
北顾笙98012 小时前
day34-数据结构力扣
数据结构·算法·leetcode
小龙报12 小时前
【数据结构与算法】一文拿捏链式二叉树:遍历 + 统计 + 层序 + 完全树
java·c语言·开发语言·c++·人工智能·语言模型·visual studio
自我意识的多元宇宙13 小时前
【数据结构】二叉排序树
数据结构·算法
量子炒饭大师13 小时前
【优化算法:双指针算法刷题宝典】—— 盛最多水的容器
c++·算法
Epiphany.55613 小时前
树上dp问题
数据结构·算法
自我意识的多元宇宙13 小时前
【数据结构】 散列表
数据结构·散列表
承渊政道13 小时前
【动态规划算法】(简单多状态dp问题入门与经典题型解析)
数据结构·c++·学习·算法·leetcode·macos·动态规划