AcWing 4378. 选取数对

给定一个长度为 nn 的整数数列 a1,a2,…,ana1,a2,…,an。

请你选择 kk 个数对 [l1,r1],[l2,r2],…,[lk,rk][l1,r1],[l2,r2],…,[lk,rk],要求所选数对满足:

  1. 1≤l1≤r1<l2≤r2<…<lk≤rk≤n1≤l1≤r1<l2≤r2<…<lk≤rk≤n。
  2. 对于 1≤i≤k1≤i≤k,ri−li+1=mri−li+1=m 均成立。
  3. 设 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;

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值