poj3661 区间dp
来源:互联网 发布:linux命令手册下载chm 编辑:程序博客网 时间:2024/06/07 16:56
原题链接
Sample Input
5 2
5
3
4
2
10
Sample Output
9
题意:
给n,m,n表示有n分钟,每i分钟对应的是第i分钟能跑的距离,m代表最大疲劳度,每跑一分钟疲劳度+1,当疲劳度==m,必须休息,在任意时刻都可以选择休息,如果选择休息,那么必须休息到疲劳度为0,当然,当疲劳度为0的时候也是可以继续选择休息的,求在n分钟后疲劳度为0所跑的最大距离。
思路:
dp[i][j]表示在第i分钟疲劳度为j的时候所跑的最大距离。
每分钟可以选择跑或者不跑,当选择跑为dp[i][j]=dp[i-1][j-1]+d[i];当休息时,必须休息到j为0,那么遍历之前所有时间的状况,值最大的则为dp[i][0]的距离,则为dp[i][0]=max(dp[i][0],dp[i-k][k]) 。
代码:
#include<iostream>#include<cstdio>#include<cstring>#include<algorithm>using namespace std;int dp[1111][555],n,m,a[1111];int main (){ while(scanf("%d%d",&n,&m)!=EOF) { for(int i=1;i<=n;i++) { scanf("%d",&a[i]); } memset(dp,0,sizeof(dp)); for(int i=1;i<=n;i++) { for(int j=1;j<=m;j++) { dp[i][j]=dp[i-1][j-1]+a[i]; dp[i][0]=dp[i-1][0]; for(int k=1;k<=m;k++) if(i>=k) dp[i][0]=max(dp[i][0],dp[i-k][k]); } } printf("%d\n",dp[n][0]); } return 0;}
0 0
- poj3661 区间dp
- poj3661,dp
- POJ3661 背包DP
- poj3661
- poj3661
- poj3661 Running
- poj3661 Running
- 区间DP
- 区间DP
- 区间DP
- 区间DP
- ##区间dp##
- 区间dp
- 区间DP
- 区间dp
- 区间dp
- 区间dp
- 区间dp
- LeetCode98—Validate Binary Search Tree
- UVA 136 Ugly Numbers
- position之absolute定位深入理解
- 工厂模式(6)
- 带有限制条件的第K个排列——CF 513B1、B2
- poj3661 区间dp
- 倒排索引原理
- ListView的优化问题以及策略
- dashboard中资源释放
- 华为基础训练---字符串分割
- Android环境搭建
- Indivisibility(最大公约数+排列组合)
- macchanger克隆MAC地址
- Linux之:最常用的20条命令