给定一个长度为 nn 的整数数列 a1,a2,…,ana1,a2,…,an。
请你选择 kk 个数对 [l1,r1],[l2,r2],…,[lk,rk][l1,r1],[l2,r2],…,[lk,rk],要求所选数对满足:
- 1≤l1≤r1<l2≤r2<…<lk≤rk≤n1≤l1≤r1<l2≤r2<…<lk≤rk≤n。
- 对于 1≤i≤k1≤i≤k,ri−li+1=mri−li+1=m 均成立。
- 设 sum=∑i=1k∑j=liriajsum=∑i=1k∑j=liriaj,sumsum 的值应尽可能大。
请你输出 sumsum 的最大可能值。
输入格式
第一行包含三个整数 n,m,kn,m,k。
第二行包含 nn 个整数 a1,a2,…,ana1,a2,…,an。
输出格式
一个整数,表示 sumsum 的最大可能值。
数据范围
前 66 个测试点满足 1≤m×k≤n≤201≤m×k≤n≤20。
所有测试点满足 1≤m×k≤n≤50001≤m×k≤n≤5000,0≤ai≤1090≤ai≤109。
输入样例1:
5 2 1
1 2 3 4 5
输出样例1:
9
输入样例2:
7 1 3
2 10 7 18 5 33 0
输出样例2:
61
记得范围和ll
二维dp
#include<cstdio>
#include<string>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;
typedef long long ll;
int a[5010];
ll dp[5010][5010];
ll e;
int n,m,k;
int main()
{ ios::sync_with_stdio(false);
cin>>n>>m>>k;
for(int i=0;i<n;i++){
cin>>a[i];
}
for(int i=1;i<=k;i++){
for(int j=m-1;j<n;j++){
e = 0;
for(int q=0;q<m;q++){
e += a[j-q];
}
dp[i][j] = max(dp[i-1][j-m] + e,dp[i][j-1]);
}
}
cout<<dp[k][n-1];
return 0;
}