Submission #573566

#TimeUsernameProblemLanguageResultExecution timeMemory
573566danikoynovFeast (NOI19_feast)C++14
21 / 100
1081 ms10556 KiB
/**
 ____ ____ ____ ____ ____ ____
||l |||e |||i |||n |||a |||d ||
||__|||__|||__|||__|||__|||__||
|/__\|/__\|/__\|/__\|/__\|/__\|

**/

#include<bits/stdc++.h>
#define endl '\n'

using namespace std;
typedef long long ll;

void speed()
{
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);
}

const int maxn = 2010;

int n, k;
ll a[maxn], dp[maxn][maxn], par[maxn];
void solve()
{
    cin >> n >> k;
    for (int i = 1; i <= n; i ++)
        cin >> a[i], par[i] = par[i - 1] + a[i];

    ll ans = 0;
    for (int i = 1; i <= n; i ++)
        for (int j = 1; j <= k; j ++)
    {
        dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
        for (int i1 = 1; i1 <= i; i1 ++)
        {
            dp[i][j] = max(dp[i][j], dp[i1 - 1][j - 1] + par[i] - par[i1 - 1]);
        }
        ans = max(ans, dp[i][j]);
    }

    cout << ans << endl;

}

int main()
{
    solve();
    return 0;
}

#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...