栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

[Acwing] 3393. 最大序列和 线性DP

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

[Acwing] 3393. 最大序列和 线性DP

前言

传送门 : https://www.acwing.com/problem/content/description/3396/
刚刚debug一波,没想到在这题又被坑了

这是Ac代码,但是这个样例输出就是不符

让我一直改 QAQ ,一交就过了

思路

看完题目大概都知道了

我们就一维状态表示:
当前位置的最大值

状态计算

  • 本身(要么本身最大) f[i] = f[i]
  • 要么可以通过前面的转移 (因为是连续的所以不会O n^2 直接O n的做就行) f[i]=f[i-1]+f[i]
CODE
#include 
using namespace std;
using ll = long long;
const int N = 1e6+10;
const int _INF =-(1<<31);
int n;

ll f[N];
ll ans = _INF;

void solve()
{
    cin>>n;

    f[0] = _INF;
    for(int i=1;i<=n;i++)
    {   
        cin>>f[i];
        f[i] =max(f[i-1]+f[i],f[i]);
    }
    
    for(int i=1;i<=n;i++)
    ans = max(f[i],ans);
    cout<
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/289882.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号