您当前的位置: 首页 > 

*DDL_GzmBlog

暂无认证

  • 0浏览

    0关注

    605博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

[Acwing] 4378. 选取数对 序列dp

*DDL_GzmBlog 发布时间:2022-03-21 12:32:18 ,浏览量:0

前言

传送门 :

思路

状态表示 f [ i ] [ j ] : f[i][j] : f[i][j]: 前 i i i个点,并且选择了 k k k个区间的最大价值

状态计算 :

  • 不选择当前 i i i端点为右端点 f [ i ] [ j ] = f [ i − 1 ] [ j ] f[i][j] = f[i-1][j] f[i][j]=f[i−1][j]
  • 选择当前的 i i i端点 f [ i ] [ j ] = m a ( f [ i − 1 ] [ j ] , f [ i − m ] [ j − 1 ] + s u m [ i ] − s u m [ i − m ] ) f[i][j] = ma(f[i-1][j],f[i-m][j-1] +sum[i] - sum[i-m]) f[i][j]=ma(f[i−1][j],f[i−m][j−1]+sum[i]−sum[i−m]) (从一个区间转移过来)
MyCode
int n,m,k;
cin>>n>>m>>k;

for(int i=1;i>a[i];
	sum[i] = sum[i-1] + a[i];
}




for(int i=1;i            
关注
打赏
1657615554
查看更多评论
0.0411s